#android #flutter #package
#Android #сбой #пакет
Вопрос:
Я пытаюсь получить доступ к информации об устройстве в приложении Flutter. На iOS
но есть ошибка на Android
.
Я добавил его в pubspec.yaml
файл в разделе зависимости:
device_info: ^0.4.2 6
и это код:
var deviceInfo = DeviceInfoPlugin();
if (Platform.isIOS) {
IosDeviceInfo iosDeviceInfo = await deviceInfo.iosInfo;
} else {
AndroidDeviceInfo androidDeviceInfo = await deviceInfo.androidInfo;
}
При вызове возникает исключение deviceInfo.androidInfo
:
Unhandled Exception: MissingPluginException(No implementation found for method getAndroidDeviceInfo on channel plugins.flutter.io/device_info)
Я попытался запустить flutter clean
и удалить приложение с устройства и установить его снова, но оно по-прежнему не работает.
Результат выполнения flutter doctor
:
Flutter (Channel master, 1.21.0-10.0.pre.115)
Я переключился на стабильный канал:
Flutter (Channel stable, 1.20.2, ... )
но ошибка все еще происходит!!
Есть предложения?!
Комментарии:
1. Можете ли вы запустить flutter doctor?
2. @LapaNyAinaTanjonaRAZAFINAH Я запускаю его, и, кажется, все правильно!!
3. Вы использовали стабильный канал?
4. @LapaNyAinaTanjonaRAZAFINAH какой канал является стабильным? Извините, но я новичок в flutter
5. Можете ли вы отредактировать свой вопрос и отобразить выходные данные flutter doctor? Я имею в виду, является ли flutter стабильным каналом или нет.
Ответ №1:
Попробуйте приведенный ниже пример для справки.
Перед этим используйте device_info: пакет ^ 0.4.0 4 в файле pubspec.yaml.
import 'dart:async';
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:device_info/device_info.dart';
void main() {
runZoned(() {
runApp(MyApp());
}, onError: (dynamic error, dynamic stack) {
print(error);
print(stack);
});
}
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
static final DeviceInfoPlugin deviceInfoPlugin = DeviceInfoPlugin();
Map<String, dynamic> _deviceData = <String, dynamic>{};
@override
void initState() {
super.initState();
initPlatformState();
}
Future<void> initPlatformState() async {
Map<String, dynamic> deviceData;
try {
if (Platform.isAndroid) {
deviceData = _readAndroidBuildData(await deviceInfoPlugin.androidInfo);
} else if (Platform.isIOS) {
deviceData = _readIosDeviceInfo(await deviceInfoPlugin.iosInfo);
}
} on PlatformException {
deviceData = <String, dynamic>{
'Error:': 'Failed to get platform version.'
};
}
if (!mounted) return;
setState(() {
_deviceData = deviceData;
});
}
Map<String, dynamic> _readAndroidBuildData(AndroidDeviceInfo build) {
return <String, dynamic>{
'version.securityPatch': build.version.securityPatch,
'version.sdkInt': build.version.sdkInt,
'version.release': build.version.release,
'version.previewSdkInt': build.version.previewSdkInt,
'version.incremental': build.version.incremental,
'version.codename': build.version.codename,
'version.baseOS': build.version.baseOS,
'board': build.board,
'bootloader': build.bootloader,
'brand': build.brand,
'device': build.device,
'display': build.display,
'fingerprint': build.fingerprint,
'hardware': build.hardware,
'host': build.host,
'id': build.id,
'manufacturer': build.manufacturer,
'model': build.model,
'product': build.product,
'supported32BitAbis': build.supported32BitAbis,
'supported64BitAbis': build.supported64BitAbis,
'supportedAbis': build.supportedAbis,
'tags': build.tags,
'type': build.type,
'isPhysicalDevice': build.isPhysicalDevice,
'androidId': build.androidId,
//'systemFeatures': build.systemFeatures,
};
}
Map<String, dynamic> _readIosDeviceInfo(IosDeviceInfo data) {
return <String, dynamic>{
'name': data.name,
'systemName': data.systemName,
'systemVersion': data.systemVersion,
'model': data.model,
'localizedModel': data.localizedModel,
'identifierForVendor': data.identifierForVendor,
'isPhysicalDevice': data.isPhysicalDevice,
'utsname.sysname:': data.utsname.sysname,
'utsname.nodename:': data.utsname.nodename,
'utsname.release:': data.utsname.release,
'utsname.version:': data.utsname.version,
'utsname.machine:': data.utsname.machine,
};
}
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text(
Platform.isAndroid ? 'Android Device Info' : 'iOS Device Info'),
),
body: ListView(
children: _deviceData.keys.map((String property) {
return Row(
children: <Widget>[
Container(
padding: const EdgeInsets.all(10.0),
child: Text(
property,
style: const TextStyle(
fontWeight: FontWeight.bold,
),
),
),
Expanded(
child: Container(
padding: const EdgeInsets.fromLTRB(0.0, 10.0, 0.0, 10.0),
child: Text(
'${_deviceData[property]}',
maxLines: 10,
overflow: TextOverflow.ellipsis,
),
)),
],
);
}).toList(),
),
),
);
}
}
Ответ №2:
Я исправил это, приведя пример ниже
flutter clean
flutter pub get
flutter run
Ответ №3:
Вам нужно оценить устройство.
DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
if (Platform.isAndroid) {
AndroidDeviceInfo androidInfo = await deviceInfo.androidInfo;
} else if (Platform.isIOS) {
IosDeviceInfo iosInfo = await deviceInfo.iosInfo;
}
Комментарии:
1. Я уже это делаю. Я просто удалил его в вопросе для простоты.
Ответ №4:
Не могли бы вы, пожалуйста, ввести весь исходный код, который вы используете? Потому что я протестировал библиотеку на своем Android 9, и она работает просто отлично.
Попробуйте этот исходный код, и он должен работать.
DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
if (Platform.isAndroid) {
AndroidDeviceInfo androidInfo = await deviceInfo.androidInfo;
print('Running on ${androidInfo.model}'); // e.g. "Moto G (4)"
} else {
IosDeviceInfo iosInfo = await deviceInfo.iosInfo;
print('Running on ${iosInfo.utsname.machine}'); // e.g. "iPod7,1"
}
Я должен также указать, что если у вас возникли какие-либо проблемы с любыми плагинами flutter или с самим flutter, лучше всего создать проблему в их репозитории:
Ответ №5:
После некоторой борьбы я обнаружил, что причина этой проблемы была из MethodChannel
. В MainActivity.java
файле я определяю канал метода:
_methodChannel = new MethodChannel(getFlutterView(), "myChannelName");
После замены getFlutterView()
на getFlutterEngine().getDartExecutor().getBinaryMessenger()
все работает нормально.
На самом деле я не знаю связи между ними, но это то, что произошло.