Java.Lang.NoSuchFieldError при использовании Mono для Android и Java-Binding

Итак, я пробую пример Xamarin Facebook Simple, который использует Java-Binding.

Столкнувшись с первоначальными проблемами, мне пришлось скачать и скомпилировать последнюю версию SDK Facebook для Android (с использованием Eclipse) и архивировать ее для проекта java-bindings на Facebook.

Однако при нажатии на кнопку выхода я получаю эту ошибку:

Java.Lang.NoSuchFieldError: com.facebook.android.R$drawable.close
  at Android.Runtime.JNIEnv.CallVoidMethod (intptr,intptr,Android.Runtime.JValue[]) [0x00023] in /Users/builder/data/lanes/monodroid-mac-monodroid-4.2.4-branch/74c352d0/source/monodroid/src/Mono.Android/src/Runtime/JNIEnv.g.cs:368
  at Com.Facebook.Android.Facebook.Authorize (Android.App.Activity,string[],Com.Facebook.Android.Facebook/IDialogListener) <IL 0x00095, 0x002af>
  at Com.Facebook.Android.LoginButton/ButtonOnClickListener.OnClick (Android.Views.View) [0x00051] in C:\Users\magnus\Downloads\xamarin-monodroid-samples-7e2c105\xamarin-monodroid-samples-7e2c105\Facebook\samples\simple\simple\Example.cs:140
  at Android.Views.View/IOnClickListenerInvoker.n_OnClick_Landroid_view_View_ (intptr,intptr,intptr) [0x00010] in /Users/builder/data/lanes/monodroid-mac-monodroid-4.2.4-branch/74c352d0/source/monodroid/src/Mono.Android/platforms/android-8/src/generated/Android.Views.View.cs:600
  at (wrapper dynamic-method) object.9681ec74-91e4-4ca3-93b5-489e6e022fb2 (intptr,intptr,intptr) <IL 0x00012, 0x0001b>

  --- End of managed exception stack trace ---
  java.lang.NoSuchFieldError: com.facebook.android.R$drawable.close
    at com.facebook.android.FbDialog.createCrossImage(FbDialog.java:106)
    at com.facebook.android.FbDialog.onCreate(FbDialog.java:81)
    at android.app.Dialog.dispatchOnCreate(Dialog.java:307)
    at android.app.Dialog.show(Dialog.java:225)
    at com.facebook.android.Facebook.dialog(Facebook.java:814)
    at com.facebook.android.Facebook.startDialogAuth(Facebook.java:343)
    at com.facebook.android.Facebook.authorize(Facebook.java:206)
    at com.facebook.android.Facebook.authorize(Facebook.java:125)
    at com.facebook.android.LoginButton_ButtonOnClickListener.n_onClick(Native Method)
    at com.facebook.android.LoginButton_ButtonOnClickListener.onClick(LoginButton_ButtonOnClickListener.java:36)
    at android.view.View.performClick(View.java:2485)
    at android.view.View$PerformClick.run(View.java:9080)
    at android.os.Handler.handleCallback(Handler.java:587)
    at android.os.Handler.dispatchMessage(Handler.java:92)
    at android.os.Looper.loop(Looper.java:130)
    at android.app.ActivityThread.main(ActivityThread.java:3683)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:507)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
    at dalvik.system.NativeStart.main(Native Method)

Использование точно такого же JAR-файла в проекте Eclipse Java прекрасно работает.
Казалось бы, что R$drawable.close ресурс отсутствует, но он присутствует в Zip-файле. Есть идеи, что может быть не так?

1 ответ

Ах да, это проблема. Это немного головная боль, но если вы посмотрите в коде Java, в диалоговом окне Facebook будет установлена ​​кнопка закрытия в коде. Поэтому, когда ваше приложение компилируется, оно не может найти идентификатор кнопки закрытия.

Обойти это можно было бы, чтобы изменить FBDialog.java файл, чтобы как-то взять в закрытии вашего ресурса integer идентификатор генерируется в файле Resource.Designer.cs.

private void createCrossImage(int value) {
    mCrossImage = new ImageView(getContext());
    // Dismiss the dialog when user click on the 'x'
    mCrossImage.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            mListener.onCancel();
            FbDialog.this.dismiss();
        }
    });
    Drawable crossDrawable = getContext().getResources().getDrawable(value);
    mCrossImage.setImageDrawable(crossDrawable);
    /* 'x' should not be visible while webview is loading
     * make it visible only after webview has fully loaded
    */
    mCrossImage.setVisibility(View.INVISIBLE);
}

Я изменил код Java и перекомпилировал файл.jar, чтобы я мог передать int ценность из моего Resources файл, так что мне не придется беспокоиться о том, что я не смог найти идентификатор этого конкретного изображения.

Другие вопросы по тегам