1

次のように定義された 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 activityan をスローし、アプリを強制的に閉じるのは最後の行です。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)
4

1 に答える 1