次のように定義された onclick ハンドラーを持つボタンがあります。
<Button
android:id="@+id/ImportCalendar"
style="?android:attr/buttonStyleSmall"
android:layout_width="wrap_content"
android:layout_height="34dp"
android:onClick="icaltesting"
android:paddingLeft="10dp"
android:text="Import" />
アクティビティ クラスで関数を定義したので、この関数を使用して最終的に Android デバイスでローカル カレンダーを作成しtesting()
たいと考えてい
ます。getContentResolver()
私が使用するコードは次のとおりです。
public void icaltesting(View view) {
Uri calUri = CalendarContract.Calendars.CONTENT_URI;
ContentValues cv = new ContentValues();
cv.put(CalendarContract.Calendars.NAME, "Test");
cv.put(CalendarContract.Calendars.CALENDAR_DISPLAY_NAME, "Local Calendar");
cv.put(CalendarContract.Calendars.VISIBLE, 1);
cv.put(CalendarContract.Calendars.SYNC_EVENTS, 1);
calUri = calUri.buildUpon()
.appendQueryParameter(CalendarContract.CALLER_IS_SYNCADAPTER, "true")
.appendQueryParameter(CalendarContract.Calendars.ACCOUNT_NAME, "Test")
.appendQueryParameter(CalendarContract.Calendars.ACCOUNT_TYPE, CalendarContract.ACCOUNT_TYPE_LOCAL)
.build();
Uri result = getContentResolver().insert(calUri, cv);
}
IllegalStateException: Could not execute method of the activity
an をスローし、アプリを強制的に閉じるのは最後の行です。getContentResolver()
関数を正しく呼び出していないと思います。この問題についてどうすればよいですか?
編集 1 関連するスタック トレースは次のとおりです。
08-23 20:05:56.580: E/AndroidRuntime(24197): FATAL EXCEPTION: main
08-23 20:05:56.580: E/AndroidRuntime(24197): java.lang.IllegalStateException: Could not execute method of the activity
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.view.View$1.onClick(View.java:3044)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.view.View.performClick(View.java:3511)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.view.View$PerformClick.run(View.java:14105)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.os.Handler.handleCallback(Handler.java:605)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.os.Handler.dispatchMessage(Handler.java:92)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.os.Looper.loop(Looper.java:137)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.app.ActivityThread.main(ActivityThread.java:4575)
08-23 20:05:56.580: E/AndroidRuntime(24197): at java.lang.reflect.Method.invokeNative(Native Method)
08-23 20:05:56.580: E/AndroidRuntime(24197): at java.lang.reflect.Method.invoke(Method.java:511)
08-23 20:05:56.580: E/AndroidRuntime(24197): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
08-23 20:05:56.580: E/AndroidRuntime(24197): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
08-23 20:05:56.580: E/AndroidRuntime(24197): at dalvik.system.NativeStart.main(Native Method)
08-23 20:05:56.580: E/AndroidRuntime(24197): Caused by: java.lang.reflect.InvocationTargetException
08-23 20:05:56.580: E/AndroidRuntime(24197): at java.lang.reflect.Method.invokeNative(Native Method)
08-23 20:05:56.580: E/AndroidRuntime(24197): at java.lang.reflect.Method.invoke(Method.java:511)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.view.View$1.onClick(View.java:3039)
08-23 20:05:56.580: E/AndroidRuntime(24197): Caused by: java.lang.IllegalArgumentException: the name must not be empty: null
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:166)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:136)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.content.ContentProviderProxy.insert(ContentProviderNative.java:415)
08-23 20:05:56.580: E/AndroidRuntime(24197): at android.content.ContentResolver.insert(ContentResolver.java:735)
08-23 20:05:56.580: E/AndroidRuntime(24197): at com.example.myfirstapp.CalendarTest.icaltesting(CalendarTest.java:117)