Android实现简单的拨号器功能

发布时间 - 2026-01-11 02:30:09    点击率:

简易拨号器的制作方法,具体如下

一、布局构造

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent">

  <TextView
    android:id="@+id/textView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="请输入电话号码:"
    android:textSize="30sp"
    />

  <EditText
    android:id="@+id/editText"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@+id/textView" />

  <Button
    android:id="@+id/dial"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/editText"
    android:text="Dial"
    android:layout_alignParentRight="true"
    android:layout_marginTop="20dp"
    android:textSize="20sp"/>
</RelativeLayout>

构造出布局如图

二、授予软件打电话权限

在AndroidManifest.xml添加如下代码

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

授予软件打电话权限,否则打不了电话

三、写代码(适用于安卓6.0以下)

1).定义一个外部类去实现setOnClickListener所需要的接口类型

package com.example.kim.phonedial;

import android.content.Intent;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
  private EditText et;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //1.加载布局
    setContentView(R.layout.activity_main);
    //3.找到控件 editText 和 Button
    et=(EditText)findViewById(R.id.editText);
    Button btn=(Button)findViewById(R.id.dial);
    //3.设置Buuton点击事件
     btn.setOnClickListener(new MyClickListener());
  }

  //4.定义一个类去实现setOnClickListener所需要的接口类型
  private class MyClickListener implements View.OnClickListener{
    public void onClick(View v){
      //5.获取 editText的文本内容
      String num=et.getText().toString().trim();
      if("".equals(num)){
        //Lenth_long 在源代码中的值为1,Length_short在源代码中的值为0
        //所以Length_long可直接写成1,Length_short可直接写成0
        Toast.makeText(MainActivity.this,"所输号码不能为空",Toast.LENGTH_LONG).show();
        return;
      }
      //6.进行拨打电话 意图Intent
      Intent intent=new Intent();//创建一个意图
      //6.1设置动作 打XX
      intent.setAction(Intent.ACTION_CALL);//设置打的动作
      //6.2设置要拨打的数据  uri类型
      // uri统一资源标识符 url统一资源定位符
      intent.setData(Uri.parse("tel:"+num));
      //6.3开启意图
      startActivity(intent);
    }
  }
}

2)匿名内部类实现setOnClickListener所需要的接口类型

package com.example.kim.phonedial;

import android.content.Intent;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
  private EditText et;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //1.加载布局
    setContentView(R.layout.activity_main);
    //3.找到控件 editText 和 Button
    et=(EditText)findViewById(R.id.editText);
    Button btn=(Button)findViewById(R.id.dial);
    //3.设置Buuton点击事件
    // btn.setOnClickListener(new MyClickListener(){});
    btn.setOnClickListener(new View.OnClickListener(){
      public void onClick(View v){
        String num=et.getText().toString().trim();
        if(num.equals("")){
          Toast.makeText(MainActivity.this,"所输入号码不能为空",Toast.LENGTH_LONG).show();
        }else{
          Intent intent=new Intent();
          intent.setAction(Intent.ACTION_CALL);
          intent.setData(Uri.parse("tel:"+num));
          startActivity(intent);
        }
      }
    });
  }
}

四、写代码(适用于安卓6.0及以上)

在Android6.0及以上平台,即便已经添加了打电话的权限,运行时依然会报错安全异常:权限被拒绝。 应该在应用启动时检查应用是否被授予电话权限。

package com.example.kim.phonedial;

import android.Manifest;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.net.Uri;
import android.provider.Settings;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
  private EditText et;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //1.加载布局
    setContentView(R.layout.activity_main);
    //3.找到控件 editText 和 Button
    et = (EditText) findViewById(R.id.editText);
    Button btn = (Button) findViewById(R.id.dial);
    //3.设置Buuton点击事件
    // btn.setOnClickListener(new MyClickListener(){});
    btn.setOnClickListener(new View.OnClickListener() {
      public void onClick(View v) {
        //检查是否获得打电话权限
        //如果没有获得电话权限
        if(ContextCompat.checkSelfPermission(MainActivity.this,
            Manifest.permission.CALL_PHONE)!= PackageManager.PERMISSION_GRANTED){
              if(ActivityCompat.shouldShowRequestPermissionRationale(MainActivity.this,
                  Manifest.permission.CALL_PHONE)){
                  //返回值:
                  //app请求过该权限,被用户拒绝,返回true
                  //用户拒绝权限,并勾选了don't ask again,返回false
                  //设备策略禁止拥有该权限,返回false

                  //提示用户授权
                  Toast.makeText(MainActivity.this,"请授予该应用电话权限",Toast.LENGTH_LONG).show();
                  //跳转到该应用设置界面,帮助用户授权
                  Intent intent=new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
                  Uri uri=Uri.fromParts("package",getPackageName(),null);
                  intent.setData(uri);
                  startActivity(intent);
              }
        }else{
          CallPhone();
        }

      }
    });
  }
  private void CheckPermission(){

  }
  private void CallPhone() {
    String num = et.getText().toString().trim();
    if (num.equals("")) {
      Toast.makeText(MainActivity.this, "所输入号码不能为空", Toast.LENGTH_LONG).show();
    } else {
      Intent intent = new Intent();
      intent.setAction(Intent.ACTION_CALL);
      intent.setData(Uri.parse("tel:" + num));
      startActivity(intent);
    }
  }
}


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android  # 拨号器  # Android电话拨号器实例详解  # Android简易电话拨号器实例详解  # Android开发之电话拨号器和短信发送器实现方法  # Android开发之电话拨号器实例详解  # Android学习笔记(二)之电话拨号器  # Android电话拨号器实现方法  # Android 2.3 拨号上网流程从源码角度进行分析  # Android Studio Intent隐式启动  # 发短信  # 拨号  # 打电话  # 访问网页等实例代码  # Android编程简单实现拨号器功能的方法  # 所需要  # 为空  # 适用于  # 加载  # 可直接  # 值为  # 源代码  # 请输入  # 如果没有  # 如图  # 跳转  # 报错  # 创建一个  # 启动时  # 大家多多  # 到该  # 勾选  # 拨打电话  # 返回值  # 被拒 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  如何彻底卸载建站之星软件?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  如何在新浪SAE免费搭建个人博客?  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  *服务器网站为何频现安全漏洞?  香港服务器租用费用高吗?如何避免常见误区?  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  利用JavaScript实现拖拽改变元素大小  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  javascript中闭包概念与用法深入理解  JavaScript如何实现音频处理_Web Audio API如何工作?  Laravel怎么使用artisan命令缓存配置和视图  如何基于云服务器快速搭建个人网站?  JavaScript模板引擎Template.js使用详解  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  Laravel如何处理CORS跨域请求?(配置示例)  Laravel如何实现多对多模型关联?(Eloquent教程)  如何快速搭建安全的FTP站点?  如何基于云服务器快速搭建网站及云盘系统?  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  微信小程序 HTTPS报错整理常见问题及解决方案  Android利用动画实现背景逐渐变暗  jQuery validate插件功能与用法详解  bing浏览器学术搜索入口_bing学术文献检索地址  利用vue写todolist单页应用  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  如何快速上传建站程序避免常见错误?  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  高性能网站服务器部署指南:稳定运行与安全配置优化方案  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  JavaScript常见的五种数组去重的方式  教你用AI润色文章,让你的文字表达更专业  如何将凡科建站内容保存为本地文件?  javascript如何操作浏览器历史记录_怎样实现无刷新导航  如何快速搭建自助建站会员专属系统?  如何实现建站之星域名转发设置?  网站制作报价单模板图片,小松挖机官方网站报价?  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  JS去除重复并统计数量的实现方法  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  EditPlus中的正则表达式 实战(1)  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  IOS倒计时设置UIButton标题title的抖动问题  Thinkphp 中 distinct 的用法解析  Python文件异常处理策略_健壮性说明【指导】  利用 Google AI 进行 YouTube 视频 SEO 描述优化  Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】  EditPlus中的正则表达式实战(5)  动图在线制作网站有哪些,滑动动图图集怎么做?