fix: 安卓选中通讯录失败问题排查

This commit is contained in:
DaisyWu 2025-05-26 19:51:06 +08:00
parent 307a96d562
commit 2c316d427f
3 changed files with 145 additions and 49 deletions

View File

@ -29,6 +29,9 @@
<uses-permission android:name="android.permission.WRITE_SETTINGS" /> <uses-permission android:name="android.permission.WRITE_SETTINGS" />
<!--允许读设备日志,用于问题排查--> <!--允许读设备日志,用于问题排查-->
<uses-permission android:name="android.permission.READ_LOGS" /> <uses-permission android:name="android.permission.READ_LOGS" />
<!--联系人-->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<!--相机--> <!--相机-->
<uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.CAMERA" />

View File

@ -20,6 +20,7 @@ import 'package:star_lock/tools/pickers/time_picker/model/pduration.dart';
import 'package:star_lock/tools/regularExpression.dart'; import 'package:star_lock/tools/regularExpression.dart';
import 'package:star_lock/tools/showTipView.dart'; import 'package:star_lock/tools/showTipView.dart';
import 'package:star_lock/tools/submitBtn.dart'; import 'package:star_lock/tools/submitBtn.dart';
import 'package:permission_handler/permission_handler.dart';
class SendElectronicKeyView extends StatefulWidget { class SendElectronicKeyView extends StatefulWidget {
SendElectronicKeyView({required this.type, Key? key}) : super(key: key); SendElectronicKeyView({required this.type, Key? key}) : super(key: key);
@ -31,6 +32,14 @@ class SendElectronicKeyView extends StatefulWidget {
class _SendElectronicKeyViewState extends State<SendElectronicKeyView> class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
with AutomaticKeepAliveClientMixin { with AutomaticKeepAliveClientMixin {
late FlutterContactPicker _contactPicker;
@override
void initState() {
super.initState();
_contactPicker = FlutterContactPicker();
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
super.build(context); super.build(context);
@ -215,19 +224,33 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
alignment: Alignment.center, alignment: Alignment.center,
child: InkWell( child: InkWell(
onTap: () async { onTap: () async {
final Contact? currentContact = try {
await logic.state.contactPicker.selectContact(); final PermissionStatus status =
if (currentContact != null) { await Permission.contacts.request();
logic.state.contact = currentContact; if (status.isGranted) {
//
final currentRoute = ModalRoute.of(context);
final Contact? currentContact =
await _contactPicker.selectContact();
//
if (currentRoute?.isCurrent == true && mounted) {
// GetX
if (Get.isRegistered<SendElectronicKeyViewLogic>(
tag: widget.type)) {
final logic = Get.find<SendElectronicKeyViewLogic>(
tag: widget.type);
if (currentContact != null) {
// //
if (currentContact.phoneNumbers != null && if (currentContact.phoneNumbers != null &&
currentContact.phoneNumbers!.isNotEmpty) { currentContact.phoneNumbers!.isNotEmpty) {
// String phoneNumber =
String phoneNumber = currentContact.phoneNumbers![0]; currentContact.phoneNumbers![0];
// //
phoneNumber = phoneNumber = phoneNumber.replaceAll(
phoneNumber.replaceAll(RegExp(r'[\s\(\)\-]'), ''); RegExp(r'[\s\(\)\-]'), '');
// ++ // ++
if (phoneNumber.startsWith('+')) { if (phoneNumber.startsWith('+')) {
phoneNumber = '+' + phoneNumber = '+' +
@ -235,12 +258,12 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
.substring(1) .substring(1)
.replaceAll(RegExp(r'[^\d]'), ''); .replaceAll(RegExp(r'[^\d]'), '');
} else { } else {
phoneNumber = phoneNumber = phoneNumber.replaceAll(
phoneNumber.replaceAll(RegExp(r'[^\d]'), ''); RegExp(r'[^\d]'), '');
} }
logic.state.emailOrPhoneController.text = phoneNumber; logic.state.emailOrPhoneController.text =
} else { phoneNumber;
logic.state.emailOrPhoneController.text = ''; logic.state.emailOrPhone.value = phoneNumber;
} }
// //
@ -248,13 +271,35 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
currentContact.fullName!.isNotEmpty) { currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text = logic.state.keyNameController.text =
currentContact.fullName!; currentContact.fullName!;
} else {
logic.state.keyNameController.text = '';
} }
// UI // UI
logic.update(); logic.update();
} }
}
}
} else {
//
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('需要通讯录权限才能选择联系人'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
} catch (e) {
print('Error selecting contact: $e');
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('获取通讯录失败,请检查权限设置'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
}, },
), ),
), ),
@ -639,18 +684,66 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
alignment: Alignment.center, alignment: Alignment.center,
child: InkWell( child: InkWell(
onTap: () async { onTap: () async {
try {
final PermissionStatus status =
await Permission.contacts.request();
if (status.isGranted) {
final Contact? currentContact = final Contact? currentContact =
await logic.state.contactPicker.selectContact(); await _contactPicker.selectContact();
logic.state.contact = currentContact!; if (currentContact != null && mounted) {
if (currentContact.phoneNumbers!.isNotEmpty) { //
logic.state.emailOrPhoneController.text = currentContact if (currentContact.phoneNumbers != null &&
.phoneNumbers![0] currentContact.phoneNumbers!.isNotEmpty) {
.replaceAll(RegExp(r'\s+\b|\b\s'), ''); String phoneNumber = currentContact.phoneNumbers![0];
//
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[\s\(\)\-]'), '');
// ++
if (phoneNumber.startsWith('+')) {
phoneNumber = '+' +
phoneNumber
.substring(1)
.replaceAll(RegExp(r'[^\d]'), '');
} else {
phoneNumber =
phoneNumber.replaceAll(RegExp(r'[^\d]'), '');
} }
if (currentContact.fullName!.isNotEmpty) { logic.state.emailOrPhoneController.text = phoneNumber;
logic.state.emailOrPhone.value = phoneNumber;
}
//
if (currentContact.fullName != null &&
currentContact.fullName!.isNotEmpty) {
logic.state.keyNameController.text = logic.state.keyNameController.text =
currentContact.fullName!; currentContact.fullName!;
} }
// UI
logic.update();
}
} else {
//
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('需要通讯录权限才能选择联系人'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
} catch (e) {
print('Error selecting contact: $e');
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('获取通讯录失败,请检查权限设置'.tr),
duration: const Duration(seconds: 2),
),
);
}
}
}, },
), ),
) )
@ -759,7 +852,7 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
child: Text( child: Text(
'取消'.tr, '取消'.tr,
style: TextStyle( style: TextStyle(
color: Colors.black, fontSize: ScreenUtil().setSp(24)), color: Colors.black, fontSize: 24.sp),
), ),
onPressed: () { onPressed: () {
Navigator.pop(context); Navigator.pop(context);
@ -802,7 +895,7 @@ class _SendElectronicKeyViewState extends State<SendElectronicKeyView>
Text( Text(
titleStr, titleStr,
style: TextStyle( style: TextStyle(
fontSize: ScreenUtil().setSp(20), color: Colors.black), fontSize: 20.sp, color: Colors.black),
), ),
], ],
), ),

View File

@ -15,8 +15,8 @@ class SendElectronicKeyViewState {
TextEditingController realNameController = TextEditingController(); // TextEditingController realNameController = TextEditingController(); //
TextEditingController idCardController = TextEditingController(); // TextEditingController idCardController = TextEditingController(); //
final FlutterContactPicker contactPicker = FlutterContactPicker(); // final FlutterContactPicker contactPicker = FlutterContactPicker();
late Contact contact; // late Contact contact;
RxBool isRemoteUnlock = false.obs; // RxBool isRemoteUnlock = false.obs; //
RxBool isAuthentication = false.obs; // RxBool isAuthentication = false.obs; //