- Android 系统概述
- 什么是智能手机?智能手机操作系统有哪些?
- Android(安卓)是什么?
- Android 系统架构(图解)
- Android 7 新特性介绍
- Android 开发环境搭建
- Android 开发环境搭建教程(图解)
- Android SDK 是什么?
- 通过 Android Studio 创建 Android 应用程序(附带解析)
- Android Studio 的基本调试
- Android 应用程序结构:Android 组件和资源详解
- Android 四大核心组件:Activity+Service+BroadcastReceiver+ContentProvider
- Android Activity 组件及其生命周期
- Android 资源(res 和 assets 目录)
- AndroidManifest.xml 配置文件详解
- Android App Widgets 组件详解
- Android 系统的进程和线程
- Android GUI(图形用户界面)开发
- Android View 和 ViewGroup
- Android 使用 XML 文件定义用户界面
- Android 五大布局:FrameLayout、LinearLayout、AbsoluteLayout、RelativeLayout 和 TableLayout
- Android 创建 Widget 组件实例详解
- Android Button:按钮控件
- Android CheckBox:多选按钮控件
- Android RadioGroup:单选按钮控件
- Android TextView:文本框控件
- Android EditText:编辑框控件
- Android Spinner:下拉列表控件
- Android AutoCompleteTextView:自动完成文本框控件
- Android DatePicker 和 TimePicker:时间日期选择器
- Android ProgressBar:进度条控件
- Android ScrollView:滚动视图
- Android SeekBar:拖动条控件
- Android RatingBar:评价条控件
- Android ImageView 和 ImageButton:图片视图和图片按钮
- Android ImageSwitcher 和 Gallery:图片切换器和图库
- Android GridView:网格视图
- Android Tab:面板标签控件
- Android 菜单:选项菜单+上下文菜单+子菜单
- Android Bitmap(点阵图像、绘制图像)
- Android 对话框(AlertDialog+ProgressDialog)
- Android 多窗口模式(分屏模式)
- Android 事件监听器和回调方法
- Android 电话短信拍照开发教程
- Android Intent:不同应用程序之间通信的桥梁
- Android 实现拨打电话功能
- Android 实现接收短信和发送短信功能
- Android 调用相机进行拍照
- Android 多媒体开发
- Android Service 生命周期和使用方法
- Android BroadcastReceiver:接收广播
- Android 音频以及音频播放器开发实例
- Android MediaRecorder 录制音频
- Android 视频以及视频播放器实例
- Android Camera 相机以及相机程序开发实例
- Android MediaRecorder 录制视频
- Android 数据存储(SQLite 数据库、Android App 数据备份和恢复 )
- Android 数据存储之 SharedPreferences
- Android 数据存储之文件存储
- Android 使用 SQLite 数据库存数数据
- Android SQLite 数据库操作实例
- Android ContentProvider(内容提供者)
- Android 使用系统提供的 ContentProvider
- Android 自定义 ContentProvider
- Android 使用自定义 ContentProvider
- Google App Engine 是什么?
- Android APP 数据备份与恢复
- Android BackupAgent 实现数据备份与恢复
- Android BackupAgentHelper 实现数据备份与恢复
- Android 网络编程
- 借助 GPE 让 Android APP 和 Google App Engine 通信
- Android HTTP 通信
- Android HttpURLConnection 访问互联网资源
- Android 通过 GET 方式获取互联网资源
- Android 通过 POST 方式获取互联网资源
- Android Socket 编程(附带实例)
- Bluetooth(蓝牙)是什么?
- Android 蓝牙通信开发教程(详解版)
- Android 蓝牙通信开发实例演示
- WIFI(无线局域网)是什么?
- Android WiFi 开发(WiFi 编程)实例演示
- WIFI Direct(WIFI 直连)是什么?
- Android WIFI Direct 开发教程
- Android WIFI Direct 开发实例演示
- NFC(近场通信)是什么?
- Android NFC 开发教程
- Android USB 开发简介
- Android USB 附件模式开发教程
- Android USB 主机模式开发教程
- Android SIP 开发教程
- Android 智能传感器
- LBS(位置服务)和 GPS(全球定位系统)简介
- Android LBS 位置服务开发简介
- Android GPS 定位开发教程
- Google Map API 开发简介
- Android Google Map API Key 详细申请步骤
- Google Map API 开发 Android 地图应用实例
- Android 传感器开发教程
- Android 运动传感器开发教程
- Android 位置传感器开发教程
- Android 环境传感器开发教程
- Android 绘图(2D 绘图、3D 绘图)
- Android 2D 绘图开发简介
- Android 使用自定义 View 绘图
- Android 使用 Bitmap 绘图
- Android 使用 SurfaceView 绘制静态图像
- Android 使用 SurfaceView 绘制动态图像
- Android Drawable 开发简介
- Android 3D 绘图开发简介
- Android 硬件加速开发简介
- Android RenderScript 开发简介
- Android App 的国际化和本地化
- Android 国际化和本地化开发简介
- Android 手机区域设置详细步骤
- Android 未本地化应用开发教程
- Android 本地化应用开发教程
- Android 文本输入与复制粘贴
- Android 剪贴板框架开发简介
- Android 剪贴板数据转文本开发简介
- Android 复制粘贴开发教程
- Android Content Provider 复制复杂数据开发教程
- Android 一键复制粘贴开发实例
- Android 企业级应用开发
- Android 设备管理 API 概述
- Android 开发设备管理 API 应用教程
- Android 文本语音 API 开发教程
- Android TV 应用开发教程
- Android TV 应用开发实例
- Android 可穿戴设备应用开发教程
- Android 应用程序的发布
- Android 应用程序发布的步骤
- Android 为什么要为应用程序签名?
- Android 导出未签名应用程序开发步骤
- Android 生成签名文件开发教程
- Android 应用程序签名开发教程
- zipalign 工具优化应用程序开发简介
- Google Play Store( Android Market)发布简介
Android SIP 开发教程
Android 系统提供了支持 SIP(Session Initiation Protocol)的 API,允许开发者添加基于 SIP 的因特网电话特性到自己的应用程序中。
Android 包含一个完整的 SIP 协议栈,整合了允许轻松创建来电和去电的电话管理服务,而不必开发者直接参与管理会话、传输层通信、音频录制等工作。
目前 SIP 已经被成功应用于视频会议和即时消息中,其应用程序开发需要基于 Android 2.3(API Level 9)以上的系统。
SIP 运行于无线数据连接,通过 AVD 无法调试。在 SIP 应用程序通信会话中,每一个参与者都必须拥有一个 SIP 账号。
相关 API
Android SDK 中与 SIP 开发相关的类和接口被放置在 android.net.sip 包中,相关类和接口介绍如下。
类/接口 | 作用 |
---|---|
SipAudioCall | 用于处理基于 SIP 的因特网音频呼叫。 |
SipAudioCall.Listener | 用于处理 SIP 呼叫事件,如接收到呼叫和对外呼叫事件。 |
SipErrorCode | 定义了 SIP 行为的错误代码。 |
SipManager | 提供了 SIP 任务的相关 API,例如初始化 SIP 连接,提供对相关 SIP 服务的访问等。 |
SipProfile | 定义了一个 SIP 配置文件,包括 SIP 账户、域和服务器信息等。 |
SipProfile.Builder | 创建 SIP 配置信息的帮助类。 |
SipSession | 代表一个与 SIP 对话框相关联的 SIP 会话或者一个单独的无对话框的事务。 |
SipSession.Listener | 针对 SIP 会话事件的监听器,例如会话被注册或者一个电话正在呼出事件。 |
SipSession.State | 定义了 SIP 会话的状态信息,例如注册、呼出、呼入等。 |
SipRegistrationListener | 一个用于监听 SIP 注册事件的接口。 |
Manifest 文件配置
要开发基于 SIP 的应用程序,必须使用 Android 2.3 以上版本的设备,但是并不是所有 Android 2.3 以上版本的设备都支持 SIP 应用程序。
为应用程序添加 SIP 支持需要在应用程序的配置文件 AndroidManifest.xml 中添加如下内容。
1)添加使用 SIP 和因特网的权限:
<uses-permission android:name="android.permission.USE_SIP" />
<uses-permission android:name="android.permission.INTERNET" />
2)确保应用程序只可以被安装在支持 SIP 的设备上,在 Manifest 文件中添加以下代码:
<uses-sdk android:minSdkVersion="9" />
<uses-feature android:name="android.hardware.sip.voip" />
3)如果应用程序被设计为接收呼叫,则必须定义一个 receiver:
<receiver android:name=".IncomingCallReceiver" android:label="Call Receiver"/>
应用程序的 Manifest 文件示例代码如下:
<?xml version="l.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.android.sip"> ... <receiver android:name=".IncomingCallReceiver" android:label="Call Receiver"/> ... <uses-sdk android:minSdkVersion="9" /> <uses-permission android:name="android.permission.USE_SIP" /> <uses-permission android:name="android.permission.INTERNET" /> ... <uses-feature android:name="android.hardware.sip.voip" android:required="true" /> <uses-feature android:name="android.hardware.wifi" android:required="true" /> <uses-feature android:name="android.hardware.microphone" android:required="true" /> </manifest>
创建 SipManager 对象
要使用 SIP API,必须创建 SipManager 示例。SipManager 用于处理:
- 初始化 SIP 会话。
- 初始化并接收呼叫。
- 对 SIP 提供者进行注册和注销。
- 核实会话连接。
创建 SipManager 对象的代码如下:
public SipManager mSipManager = null; ... if(mSipManager == null){ mSipManager = SipManager.newInstance(this); }
注册 SIP 服务器
在典型的 Android SIP 应用程序中包含一个或多个用户,每个用户都必须有一个 SIP 账户。在 SIP 应用程序中,SIP 账户用 SipProfile 对象表示。
SipProfile 定义了 SIP 配置简表,包括 SIP 账户以及域和服务器信息。与运行应用程序的设备上的 SIP 账户相关联的配置简表叫作本地简表,会话连接到的简表叫作对等简表。
当 SIP 应用程序使用本地 SipProfile 登录到 SIP 服务器时,SipProfile 帮助 SIP 服务器高效地将当前设备注册为 SIP 呼叫的目的地。
创建 SipProfile 对象的代码如下:
public SipProfile mSipProfile = null; ... SipProfile.Bulider bulider = new SipProfile(username,domain); bulider.setPassword(password); mSipProfile = builder.bulid();
下面代码中的 SipManager 打开本地简表,用于拨打或者接收 SIP 呼叫:
Intent intent - new Intent(); intent.setAction("android.SipDemo.INCOMING_CALL"); PendingIntent pendingIntent = PendingIntent.getBroadcast(this,0,intent,Intent.FILL_IN_DATA); mSipManager.open(mSipProfile,pendingIntent,null);
下面的代码为 SipManager 注册了 SipRegistrationListener 接口,该接口用于跟踪 SipProfile 是否在 SIP 服务提供者处成功注册。
SipManager.setRegistrationListener (mSipProfile.getUriString(), new SipRegistrationListener(){ public void onRegistering (String localProfileUri) { updateStatus ("Registering with SIP Server..."); } public void onRegistrationDone (String localProfileUri, long expiryTime){ updateStatus ("Ready"); } public void onRegistrationFailed (String localProfileUri, int errorCode, String errorMessage) { updateStatus ("Registration failed. Please check settings."); }
下面的代码演示了配置简表使用结束后,如何关闭简表,并从服务器注销设备信息。
public void closeLocalProfile(){ if (mSipManager==null) { return; } try { if (mSipProfile !=null) { mSipManager.close (mSipProfile.getUriString()); } } catch (Exception e) { Log.d ("WalkieTalkieActivity/onDestroy", "Failed to close local profile.", e); } }
拨打音频电话
要使用 SIP 拨打语音电话,需要满足如下条件:
- 一个 SipProfile 对象,用于拨打电话;一个有效的 SIP 地址,用于接收电话。
- 一个 SipManager 对象。
为了拨打音频电话,需要创建 SipAudioCall.Listener 对象。
大部分的客户端与 SIP 栈之间的交互都是通过接口进行的。下面的代码演示了呼叫建立后接口如何进行处理:
SipAudioCall.Listener listener=new SipAudioCall.Listener(){ @Override public void onCallEstablished (SipAudioCall call) { call.startAudio(); call.setSpeakerMode (true); call.toggleMute(); ... } @Override public void onCallEnded (SipAudioCall call) { // Do something. } };
SipAudioCall.Listener 接口创建后,通过 SipManager.makeAudioCall() 方法进行音频呼叫。该方法有 4 个参数,分别是:
- 本地 SIP 配置简表(呼叫者)。
- 对等 SOP 配置简表(被呼叫者)。
- SipAudioCall.Listener 接口。
- 超时时间,单位是秒。
进行音频呼叫的代码如下:
call=mSipManager.makeAudioCall(mSipProfile.getUriString(),sipAddress, listener, 30);
接收呼叫
为了接收呼叫,SIP 应用程序必须包含一个 BroadcastReceiver 的子类,以便当有来电时用于对 Intent 对象进行处理。为此,需要在应用程序中完成以下几步:
1)在 AndroidManifest.xml 文件中声明 <receiver>,例如:
<receiver android:name=".IncomingCallReceiver" android:label="Call Receiver"/>2)
2)实现声明的 BroadcastReceiver 的子类,例如 IncomingCallReceiver。
3)使用 PendingIntent 对象初始化本地 SipProfile。当有来电时,该 PendingIntent 会启动 BroadcastReceiver 的子类。
4)设置 Intent Filter,用于过滤来电时产生的 Intent。
下面的代码定义了一个用于处理来电的 BroadcastReceiver:
/*** Listens for incoming SIP calls, intercepts and hands them off to WalkieTalkieActivity. */ public class IncomingCallReceiver extends BroadcastReceiver { /** *Processes the incoming call, answers it, and hands it over to the *WalkieTalkieActivity. *@param context The context under which the receiver is running. *Sparam intent The intent being received. */ @Override public void onReceive (Context context, Intent intent) { SipAudioCall incomingCall=null; try { SipAudioCall.Listener listener=new SipAudioCall.Listener(){ @Override public void onRinging (SipAudioCall call, SipProfile caller) { try { call.answerCall (30) ; } catch (Exception e) { e.printStackTrace (); } } }; WalkieTalkieActivity wtActivity= (WalkieTalkieActivity) context; incomingCall=wtActivity.mSipManager.takeAudioCall (intent, listener); incomingCall.answerCall (30); incomingCall.startAudio(); incomingCall.setSpeakerMode (true); if (incomingCall.isMuted()) { incomingCall.toggleMute(); } wtActivity.call=incomingCall; wtActivity.updateStatus (incomingCall); } catch (Exception e) { if (incomingCall !=null) { incomingCall.close(); } } }
设置用于接收来电的 Intent Filter 的相关代码如下:
public SipManager mSipManager=null; public SipProfile mSipProfile=null; ... Intent intent=new Intent(); intent.setAction ("android.SipDemo.INCOMING_CALL"); PendingIntent pendingIntent=PendingIntent.getBroadcast (this, 0,intent,Intent.FILL_IN_DATA); mSipManager.open (mSipProfile, pendingIntent, null);
Intent Filter 信息可以在应用程序的 Manifest 文件中被注册,也可以像下面的代码演示的那样在 Activity 的 onCreate() 方法中被注册。相关代码如下:
public class WalkieTalkieActivity extends Activity implements View.OnTouchListener { ... public IncomingCallReceiver callReceiver; ... @Override public void onCreate (Bundle savedInstanceState) { IntentFilter filter=new IntentFilter(); filter.addAction ("android.SipDemo.INCOMING_CALL"); callReceiver=new IncomingCallReceiver(); this.registerReceiver (callReceiver, filter); ... } ... }
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论