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
файл, так что мне не придется беспокоиться о том, что я не смог найти идентификатор этого конкретного изображения.