- 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 WIFI Direct 开发教程
创建一个 WIFI Direct 应用程序,包括发现连接点、请求连接、建立连接、发送数据,以及建立对该应用程序广播的 Intent 进行接收的 BroadcastReceiver,需要经过以下步骤。
1. 创建 BroadcastReceiver
需要注意的是,要在 BroadcastReceiver 的构造方法中传入 WifiP2pManager、WifiP2pManager.Channel 以及注册该 BroadcastReceiver 的 Activity 的对象,以便在 BroadcastReceiver 中访问 WIFI 硬件设备并对 Activity 进行更新。
创建 BroadcastReceiver 的代码如下:
public class WiFiDirectBroadcastReceiver extends BroadcastReceiver {
private WifiP2pManager manager;
private Channel channel;
private MyWiFiActivity activity;
public WiFiDirectBroadcastReceiver (WifiP2pManager manager, Channel channel,MyWifiActivity activity) {
super();
this.manager=manager;
this.channel=channel;
this.activity=activity;
}
@Override
public void onReceive(Context context, Intent intent) {
String action=intent.getAction();
if (WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTI0N.equals (action)) {
//检测 WIFI 功能是否被打开
} else if (WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION.equals (action)) {
//获取当前可用连接点的列表
} else if (WifiP2pManager.WIFI_P2P_CONNECTION_CHANGED_ACTION.equals (action)) {
//建立或者断开连接
} else if (WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTION.equals (action)) {
//当前设备的 WIFI 状态发生变化
}
}
}2. 初始化操作
1)修改 Android Manifest.xml 文件
指定支持 WIFI Direct 的 Android SDK 的最小版本并增加使用 WIFI Direct 的相应权限,代码如下:
<uses-sdk android:minSdkVersion="14" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
2)确认当前设备是否支持并且打开了 WIFI Direct 功能
相关代码应该被放在 BroadcastReceiver 的 onReceive() 方法中。实例代码如下:
public void onReceive (Context context, Intent intent) {
...
String action=intent.getAction();
if (WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTI0N.equals (action)) {
int state=intent.getIntExtra (WifiP2pManager.EXTRA_WIFI_STATE, -1);
if (state==WifiP2pManager.WIFI_P2P_STATE_ENABLED) {
// Wifi Direct is enabled
} else {
// Wi-Fi Direct is not enabled
}
}
...
}3)在 Activity 的 onCreate() 方法中创建对象
创建 WifiP2pManager 和 Channel 对象,并创建 BroadcastReceiver 对象,代码如下:
WifiP2pManager mManager;
Channel mChannel;
BroadcastReceiver mReceiver;
...
@Override
protected void onCreate (Bundle savedInstanceState) {
...
mManager= (WifiP2pManager) getSystemService (Context.WIFI_P2P_SERVICE);
mChannel=mManager.initialize (this, getMainLooper(), null);
mReceiver=new WiFiDirectBroadcastReceiver (manager, channel, this);
...
}4)创建 BroadcastReceiver 要使用的 IntentFilter 对象
代码如下:
IntentFilter mIntentFilter;
...
@Override
protected void onCreate (Bundle savedInstanceState) {
...
mIntentFilter=new IntentFilter();
mIntentFilter.addAction (WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTI0N);
mIntentFilter.addAction (WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTI0N);
mIntentFilter.addAction (WifiP2pManager.WIFI_P2P_C0NNECTI0N_CHANGED_ACTI0N);
mIntentFilter.addAction (WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTI0N);
...
}5)在 Activity 的 onResume() 方法中注册 BroadcastReceiver 对象,在 onPause() 方法中注销对象
代码如下:
@Override
protected void onResume(){
super.onResume();
registerReceiver(mReceiver, mIntentFilter);
}
/*unregister the broadcast receiver */
@Override
protected void onPause(){
super.onPause();
unregisterReceiver(mReceiver);
}3. 使用 WifiP2pManager.discoverPeers() 方法获取可以连接点的列表
示例代码如下:
manager.discoverPeers (channel, new WifiP2pManager.ActionListener() {
@Override
public void onSuccess(){
...
}
@Override
public void onFailure (int reasonCode) {
...
}
});若成功搜寻到可以连接的点,则 WIFI Direct 系统框架会广播一个带有 WIFI_P2P_ PEERS_CHANGED_ACTION 信息的 Intent,该 Intent 会被之前定义的 BoradcastReceiver 接收,并获得可以连接点的列表。示例代码如下:
PeerListListener myPeerListListener;
...
if (WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION.equals (action)) {
if (manager !=null) {
manager.requestPeers (channel, myPeerListListener);
}
}4. WifiP2pManager.connect() 方法可以与列表中的某个连接点设备建立连接,该方法通过 WifiP2pConfig 对象获得连接设备的相关信息
示例代码如下:
WifiP2pDevice device;
WifiP2pConfig config=new WifiP2pConfig();
config.deviceAddress=device.deviceAddress;
manager.connect (channel, config, new ActionListener () {
@Override
public void onSuccess(){
//success logic
}
@Override
public void onFailure (int reason) {
//failure logic
}
});5. 连接建立后,就可以用两个设备直接通过 Socket 进行数据传输
其传输过程与之前讲解的 Socket 通信完全相同,基本步骤如下:
1)在其中一个设备上建立 ServerSocket 对象,监听特定端口,并堵塞应用程序,直到有连接请求。
2)在另一个设备上建立 Socket 对象,通过 IP 地址和端口向 ServerSocket 发出连接请求。
3)ServerSocket 监听到连接请求后,调用 accept() 方法建立连接。
4)连接建立后,Socket 对象可以通过字节流在两个设备间直接进行数据传递。
下面的示例代码演示了通过 ServerSocket 和 Socket 在客户端和服务器间直接传递 JPG 图像的过程。
服务器代码如下:
public static class FileServerAsyncTask extends AsyncTask {
private Context context;
private TextView statusText;
public FileServerAsyncTask(Context context, View statusText) {
this.context = context;
this.statusText = (TextView) statusText;
}
@Override
protected String doInBackground(Void... params) {
try {
//创建 ServerSocket 对象,监听 8888 端口,等待客户连接
ServerSocket serverSocket = new ServerSocket(8888);
Socket client = serverSocket.accept();
//建立连接成功,开始传送数据
final File f = new File(Environment.getExternalStorageDirectory() + "/"
+ context.getPackageName() + "/wifip2pshared-" + System.currentTimeMillis() + ".jpg");
File dirs = new File(f.getParent());
if (!dirs.exists())
dirs.mkdirs();
f.createNewFile();
InputStream inputstream = client.getlnputStream();
copyFile(inputstream, new FileOutputStream(f));
ServerSocket.close();
return f.getAbsolutePath();
} catch (IOException e) {
Log.e(WiFiDirectActivity.TAG, e.getMessage());
return null;
}
}
//启动用于显示图像的 Activity
@Override
protected void onPostExecute(String result) {
if (result != null) {
statusText.setText("File copied - " + result);
Intent intent = new Intent();
intent.setAction(android.content.Intent.ACTION_VIEW);
intent.setDataAndType(Uri.parse("file://" + result),"image/*");
context.startActivity(intent);
}
}
}客户端的相关代码如下:
Context context=this.getApplicationContext(); String host; int port; int len; Socket socket =new Socket(); byte buf[]=new byte[1024]; ... try{ //创建 Socket 对象,并请求连接 socket.bind (null); socket.connect((new InetSocketAddress(host,port)),500); //连接建立成功,开始传输数据 OutputStream outputStream=socket.getOutputStream(); ContentResolver cr=context.getContentResolver(); Inputstream inputStream=null; inputstream=cr.openlnputStream(Uri.parse("path/to/picture.jpg"))while((len=inputStream.read(buf))!=-l){outputStream.write(buf,0,len); outputStream.close(); inputstream.close(); }catch(FileNotFoundException e){ //catch logic } catch (IOException e) { //catch logic } //关闭连接 finally{ if(socket!=null){ if(socket.isConnected()){ try{ socket.close(); }catch(IOException e){ //catch logic } } } }
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论