如何解决如何在 Flutter 中将电话呼叫操作添加到我的 ListTile
我正在为社区编写一个工具。我的目的是在 listtile 中给出名字姓氏和数字,当人们点击名字时,它会拨打指定的号码。我试过 url_launcher 但我做不到。可以检查并告诉我我的代码有什么问题。这是我无法启动的代码,有什么我想念的吗?
import 'package:Flutter/material.dart';
import 'package:Flutter/rendering.dart';
import 'package:sarisayfav1/Gas.dart';
import 'package:sarisayfav1/Kargo.dart';
import 'package:sarisayfav1/Tamir.dart';
import 'package:url_launcher/url_launcher.dart';
import 'Book.dart';
import 'Food.dart';
class arac extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Akcakale Sari Sayfa',theme: ThemeData(
backgroundColor: Colors.black87,primaryColor: Colors.black,visualDensity: VisualDensity.adaptivePlatformDensity,),home: MyHomePage(title: 'Akçakale Sarı Sayfa'),);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key,this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
drawer: Drawer(
child: ListView(
// Important: Remove any padding from the ListView.
padding: EdgeInsets.zero,children: <Widget>[
DrawerHeader(
child: Text('Akçakale Sarı Sayfa Uygulaması',style: TextStyle(color: Colors.AmberAccent,fontSize: 25)),decoration: Boxdecoration(
color: Colors.black87,ListTile(
leading: Icon(Icons.directions_bus),title: Text(
'Kargo Telefon Numaraları',onTap: () {
Navigator.push(context,new MaterialPageRoute(builder: (context) => new Kargo()));
// Update the state of the app.
// ...
},ListTile(
leading: Icon(Icons.food_bank_outlined),title: Text(
'Lokanta-Yiyecek-İçecek',new MaterialPageRoute(builder: (context) => new Food()));
// Update the state of the app.
// ...
},ListTile(
leading: Icon(Icons.menu_book_rounded),title: Text(
'Kırtasiye-Kitapçı',new MaterialPageRoute(builder: (context) => new Book()));
// Update the state of the app.
// ...
},ListTile(
leading: Icon(Icons.local_gas_station),title: Text('Tüpçü-Sucu'),new MaterialPageRoute(builder: (context) => new Gas()));
},ListTile(
leading: Icon(Icons.home_repair_service),title: Text(
'Elektrik-Su-Mobilya Tamircisi',new MaterialPageRoute(builder: (context) => new Tamir()));
// Update the state of the app.
// ...
},ListTile(
leading: Icon(Icons.local_taxi),title: Text('Taşıma Hizmeti Sağlayan Özel araç Sahipleri'),new MaterialPageRoute(builder: (context) => new arac()));
},],appBar: AppBar(
leading: Icon(Icons.settings),backgroundColor: Colors.black87,title: Text(widget.title,style: TextStyle(color: Colors.AmberAccent)),body: ListTile(
leading: Icon(Icons.person),dense: true,onTap: () => tel:+123456789,// This trailing comma makes auto-formatting nicer for build methods.
);
}
}
解决方法
您需要删除电话号码中的空格(如果有),以便本机电话应用程序正确设置号码格式(例如 +1 234 567 8901)。我认为问题只出现在 iOS 中,因为即使有空格,Android 也能正确格式化。
import 'package:url_launcher/url_launcher.dart' as UrlLauncher;
_launchUrl(String phoneNumber) async {
try {
if (phoneNumber != null) {
phoneNumber = phoneNumber.replaceAll(" ","");
if (await UrlLauncher.canLaunch(phoneNumber)) {
await UrlLauncher.launch(phoneNumber);
}
}
} catch(e){
print('Cannot launch url');
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。