Срыв флаттера contact_picker на android - PullRequest
0 голосов
/ 02 мая 2020

Кажется, я не могу понять это.

Я добавил разрешение на чтение контактов в мой android / app / src / main / AndroidManifest. xml

<uses-permission android:name="android.permission.READ_CONTACTS"/>

Я тоже с помощью license_handler

    bool status = await Permission.contacts.request().isGranted;

    if (status) {
     Contact contact = await _contactPicker.selectContact();
     //get contact info
    }

отображается экран контактов, но как только я выбираю контакт, приложение вылетает.

вот журналы сразу после касания контакта.

D/AndroidRuntime(17070): Shutting down VM
E/AndroidRuntime(17070): FATAL EXCEPTION: main
E/AndroidRuntime(17070): Process: com.medlog.app, PID: 17070
E/AndroidRuntime(17070): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=2015, result=-1, data=Intent { dat=content://com.android.contacts/data/2426 flg=0x1 }} to activity {com.medlog.app/com.medlog.app.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.ContentResolver android.app.Activity.getContentResolver()' on a null object reference
E/AndroidRuntime(17070):    at android.app.ActivityThread.deliverResults(ActivityThread.java:5202)
E/AndroidRuntime(17070):    at android.app.ActivityThread.handleSendResult(ActivityThread.java:5243)
E/AndroidRuntime(17070):    at android.app.servertransaction.ActivityResultItem.execute(ActivityResultItem.java:51)
E/AndroidRuntime(17070):    at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:140)
E/AndroidRuntime(17070):    at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:100)
E/AndroidRuntime(17070):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2239)
E/AndroidRuntime(17070):    at android.os.Handler.dispatchMessage(Handler.java:107)
E/AndroidRuntime(17070):    at android.os.Looper.loop(Looper.java:227)
E/AndroidRuntime(17070):    at android.app.ActivityThread.main(ActivityThread.java:7822)
E/AndroidRuntime(17070):    at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime(17070):    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
E/AndroidRuntime(17070):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1026)
E/AndroidRuntime(17070): Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.ContentResolver android.app.Activity.getContentResolver()' on a null object reference
E/AndroidRuntime(17070):    at vn.sendo.flutter.contactpicker.ContactPickerPlugin.onActivityResult(ContactPickerPlugin.java:83)
E/AndroidRuntime(17070):    at io.flutter.embedding.engine.FlutterEnginePluginRegistry$FlutterEngineActivityPluginBinding.onActivityResult(FlutterEnginePluginRegistry.java:634)
E/AndroidRuntime(17070):    at io.flutter.embedding.engine.FlutterEnginePluginRegistry.onActivityResult(FlutterEnginePluginRegistry.java:367)
E/AndroidRuntime(17070):    at io.flutter.embedding.android.FlutterActivityAndFragmentDelegate.onActivityResult(FlutterActivityAndFragmentDelegate.java:546)
E/AndroidRuntime(17070):    at io.flutter.embedding.android.FlutterActivity.onActivityResult(FlutterActivity.java:594)
E/AndroidRuntime(17070):    at android.app.Activity.dispatchActivityResult(Activity.java:8303)
E/AndroidRuntime(17070):    at android.app.ActivityThread.deliverResults(ActivityThread.java:5195)
E/AndroidRuntime(17070):    ... 11 more
I/Process (17070): Sending signal. PID: 17070 SIG: 9

Вот мой флаттер доктор

[✓] Flutter (Channel stable, v1.12.13+hotfix.9, on Mac OS X 10.15.4 19E287, locale en-PH)

[✓] Android toolchain - develop for Android devices (Android SDK version 29.0.3)
[✓] Xcode - develop for iOS and macOS (Xcode 11.4.1)
[✓] Android Studio (version 3.6)
[!] VS Code (version 1.44.2)
    ✗ Flutter extension not installed; install from
      https://marketplace.visualstudio.com/items?itemName=Dart-Code.flutter
[✓] Connected device (2 available)

! Doctor found issues in 1 category.

Кстати, это прекрасно работает на iOS.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...