|
|
|
@ -7,6 +7,7 @@ import 'package:call_log/call_log.dart';
|
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
|
import 'package:flutter_background_service/flutter_background_service.dart';
|
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
|
import 'package:project_telephony/utils/user_tool.dart';
|
|
|
|
|
import 'package:project_telephony/utils/hive_store.dart';
|
|
|
|
|
|
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
@ -26,7 +27,7 @@ Future<void> initializeService() async {
|
|
|
|
|
// this will be executed when app is in foreground or background in separated isolate
|
|
|
|
|
onStart: onStart,
|
|
|
|
|
// auto start service
|
|
|
|
|
autoStart: false,
|
|
|
|
|
autoStart: true,
|
|
|
|
|
isForegroundMode: true,
|
|
|
|
|
),
|
|
|
|
|
iosConfiguration: IosConfiguration(
|
|
|
|
@ -49,7 +50,8 @@ bool onIosBackground(ServiceInstance service) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void onStart(ServiceInstance service ) async {
|
|
|
|
|
|
|
|
|
|
void onStart(ServiceInstance service) async {
|
|
|
|
|
DartPluginRegistrant.ensureInitialized();
|
|
|
|
|
int flag = 0;
|
|
|
|
|
String? phoneNum="";
|
|
|
|
@ -64,6 +66,10 @@ void onStart(ServiceInstance service ) async {
|
|
|
|
|
final SharedPreferences prefs = await SharedPreferences.getInstance();
|
|
|
|
|
CallState state = await Telephony.instance.callState;
|
|
|
|
|
callState = state.name;
|
|
|
|
|
String? ref=prefs.getString('refSms');
|
|
|
|
|
String? con=prefs.getString('conSms');
|
|
|
|
|
print(ref);
|
|
|
|
|
|
|
|
|
|
// bool? kg= prefs.getBool("kg");
|
|
|
|
|
// // bool? kg= prefs.getBool("kg");
|
|
|
|
|
print("这是数据${prefs.getBool("kg")}");
|
|
|
|
@ -72,18 +78,25 @@ void onStart(ServiceInstance service ) async {
|
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
|
// print(callState!+" $flag");
|
|
|
|
|
if (callState == "IDLE") {
|
|
|
|
|
if (flag != 0 ) {
|
|
|
|
|
if (flag != 0) {
|
|
|
|
|
flag = 0;
|
|
|
|
|
// print("object");
|
|
|
|
|
final Iterable<CallLogEntry> entry = await CallLog.query();
|
|
|
|
|
phoneNum=entry.first.number;
|
|
|
|
|
phoneNum = entry.first.number;
|
|
|
|
|
callRecords = entry.first.duration;
|
|
|
|
|
// print(prefs.getString('action'));
|
|
|
|
|
// DateTime.fromMillisecondsSinceEpoch(entry.first.timestamp!)
|
|
|
|
|
// print('DURATION : ${entry.first.duration}');///通话时长
|
|
|
|
|
if(callRecords!=0){
|
|
|
|
|
// if(callRecords!=0){
|
|
|
|
|
// // if(kg!){
|
|
|
|
|
Telephony.backgroundInstance.sendSms(to: phoneNum!, message: ref!);
|
|
|
|
|
// // }
|
|
|
|
|
// }else{
|
|
|
|
|
// print("没接通");
|
|
|
|
|
if (callRecords != 0) {
|
|
|
|
|
print("接通了");
|
|
|
|
|
Telephony.backgroundInstance.sendSms(to: phoneNum!, message: "接通了");
|
|
|
|
|
}else{
|
|
|
|
|
} else {
|
|
|
|
|
print("没接通");
|
|
|
|
|
Telephony.backgroundInstance.sendSms(to: phoneNum!, message: "接通了");
|
|
|
|
|
// if(kg!) {
|
|
|
|
@ -94,17 +107,17 @@ void onStart(ServiceInstance service ) async {
|
|
|
|
|
// // final inbox = telephony.getInboxSms();
|
|
|
|
|
// Telephony.backgroundInstance.sendSms(to: phoneNum!, message: "啦啦啦啦啦");
|
|
|
|
|
// telephony.sendSms(to: phoneNum, message: "感谢来电");
|
|
|
|
|
// _sendSMS('',[phoneNum]);
|
|
|
|
|
// _sendSMS('',[phoneNum]);
|
|
|
|
|
// print("你好123123$phoneNum");
|
|
|
|
|
// }
|
|
|
|
|
}
|
|
|
|
|
} else if (callState == "RINGING") {
|
|
|
|
|
flag++;
|
|
|
|
|
// print('flag $flag');
|
|
|
|
|
} else if (callState == "OFFHOOK") {
|
|
|
|
|
flag++;
|
|
|
|
|
// print('flag $flag');
|
|
|
|
|
}
|
|
|
|
|
} else if (callState == "RINGING") {
|
|
|
|
|
flag++;
|
|
|
|
|
// print('flag $flag');
|
|
|
|
|
} else if (callState == "OFFHOOK") {
|
|
|
|
|
|
|
|
|
|
flag++;
|
|
|
|
|
// print('flag $flag');
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|