九、Android学习第八天——广播机制与WIFI网络操作(转)

(转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html)

九、Android学习第八天——广播机制与WIFI网络操作

今天熟悉了Android中的广播机制与WIFI网络的一些基本操作,总结如下:

  • Android的广播机制

我们知道广播机制中,发送方不会关心接收方时候接收到数据或者如何去处理数据。

这里总结下Android中BroadcastReceiver的注册方法:

(一)在应用程序中进行注册

(二)在Manifest.xml中进行注册

如果在Manifest.xml中进行注册,那么该应用程序无论是开还是关,该应用都会收到广播事件。例如:监听电池耗电量等。显而易见,这种注册方法并不是我们想要的。

如果在应用程序中进行注册,就会在Activity可见时进行注册,不可见时就会取消注册。

在Activity中进行注册的代码如下:

注册:registerReceiver(BroadcastReceiver receiver,IntentFilter filter);

取消注册:unregisterReceiver(BroadcastReceiver receiver);

如果一个BroadcastReceiver用于更新UI,那么通常会使用在代码中注册的方法。

  • WIFI基本操作

WIFI应该说是Android中比较重要的一块了,用Android系统手机的童鞋们,应该每天都在接触WIFI。

今天熟悉了如何对WIFI网卡进行基本的操作,包括打开,关闭,检测网卡状态等等。

WIFI网卡的状态是有一系列整型常量来表示的,如下:

(一)WIFI_STATE_DISABLED WIFI网卡不可用——1

(二)WIFI_STATE_DISABLING WIFI网卡正在关闭——0

(三)WIFI_STATE_ENABLED WIFI网卡可用状态——3

(四)WIFI_STATE_ENABLING WIFI网卡正在打开——2

(五)WIFI_STATE_UNKNOWN 未知网卡状态——4

大家注意到了,每个状态后我写了一个数字,我们知道这些都是整型常量,所以后面的数字就是这些常量对应的值,如果大家在程序中,输出当前当卡的状态,就会看到这些数值,对应着某种网卡的状态。

操作Android WIFI网卡状态中,比较重要的是操作WIFI网卡需要的权限,这个有很多。

我们在Android API中可以找到Manifest.permission类,就可以看到各种权限了。

这里贴出WIFI的一个例子,WIFI的这个例子只能在真机上面测试,因为模拟器没有WIFI这样的功能。

这里比较重要的有三个文件:

WIFITestActivity.java

main.xml

Manifest.xml

下面来看看这三个文件中的具体代码:

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="WIFI" />
<Button
android:id="@+id/open"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="打开wifi" 
/>
<Button
android:id="@+id/close"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="关闭wifi" 
/>
<Button
android:id="@+id/check"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="检查wifi状态" 
/>
</LinearLayout>

WIFITestActivity.java

package mickey.wifi;

import android.app.Activity;
import android.content.Context;
import android.net.wifi.WifiManager;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;

public class WIFITestActivity extends Activity {

// 三个控件对象
private Button open = null;
private Button close = null;
private Button check = null;

// 我们知道要对网卡进行操作,就需要WifiManager这个类
private WifiManager wifiManager = null;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

// 得到控件对象的实例,并且为他们设置相应的监听器
open = (Button) findViewById(R.id.open);
open.setOnClickListener(new OpenWifiListener());
close = (Button) findViewById(R.id.close);
close.setOnClickListener(new CloseWifiListener());
check = (Button) findViewById(R.id.check);
check.setOnClickListener(new CheckWifiListener());
}

// 为打开网卡按钮设置监听器
class OpenWifiListener implements OnClickListener {
@Override
public void onClick(View arg0) {
// 内部类如果直接使用this的话代表的是它自己,所以要用WIFITestActivity.this
// 得到WIFIManager对象
wifiManager = (WifiManager) WIFITestActivity.this
.getSystemService(Context.WIFI_SERVICE);
// setWifiEnabled(true) 打开wifi网卡
wifiManager.setWifiEnabled(true);

// 得到当前网卡的状态,这儿输出的是一个整型常量
System.out.println("当前网卡的状态为:" + wifiManager.getWifiState());

// 弹出一个Toast提示用户当前wifi网卡的状态是什么,记得调用show方法
Toast.makeText(WIFITestActivity.this,
"当前wifi网卡的状态为" + wifiManager.getWifiState(),
Toast.LENGTH_SHORT).show();
}
}

// 为关闭网卡按钮设置监听器
class CloseWifiListener implements OnClickListener {
@Override
public void onClick(View arg0) {
// 得到WIFIManager对象
wifiManager = (WifiManager) WIFITestActivity.this
.getSystemService(Context.WIFI_SERVICE);
// 设置网卡不可用
wifiManager.setWifiEnabled(false);
System.out.println("当前网卡的状态为:" + wifiManager.getWifiState());
Toast.makeText(WIFITestActivity.this,
"当前wifi网卡的状态为" + wifiManager.getWifiState(),
Toast.LENGTH_SHORT).show();
}
}

// 为检查网卡状态按钮设置监听器
class CheckWifiListener implements OnClickListener {
@Override
public void onClick(View arg0) {
// 得到WIFIManager对象
wifiManager = (WifiManager) WIFITestActivity.this
.getSystemService(Context.WIFI_SERVICE);
System.out.println("当前网卡的状态为:" + wifiManager.getWifiState());
Toast.makeText(WIFITestActivity.this,
"当前wifi网卡的状态为" + wifiManager.getWifiState(),
Toast.LENGTH_SHORT).show();

}
}
}

Manifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="mickey.wifi"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk android:minSdkVersion="10" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:label="@string/app_name"
android:name=".WIFITestActivity" >
<intent-filter >
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>

<!-- 这四个权限一定要有,否则系统不会赋予用户操作网络及网卡的权限 -->
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
</manifest>

然后童鞋们,把基于Android系统的手机用USB数据线连接到电脑,记得把USB调试打开,然后运行你的程序,就会自动在手机上运行这个程序啦~

时间: 2024-07-31 14:30:43

九、Android学习第八天——广播机制与WIFI网络操作(转)的相关文章

Android学习总结——本地广播机制

为了简单解决广播的安全性问题,Android引入了一套本地广播机制,使用这个机制发出的广播只能在程序的内部进行传递,只能接受来自本应用程序发出的广播.否则当我们发送一些携带关键数据的广播可能被截获,一些恶意程序也可能向我们的广播接收器中发送各种垃圾广播. 用法如下:(主要就是使用LocalBroadcastManager来对广播进行管理,并提供注册广播和发送广播的方法). package com.example.xch.localbroadcast; import android.content

Android 学习笔记 BroadcastReceiver广播...

PS:不断提升自己,是件好事... 学习内容: 1.BroadcastReceiver的使用.. 2.通过BroadcastReceiver去启动Service... 1.BroadcastReceiver...   广播接收者,用来接收系统和应用中的广播...Android广播机制用的地方还是很多的,比如说:当网络状态发生改变的时候,通过接收这条广播就能及时做出相应的响应,然后完成一些操作..这就是广播的机制...它自身并不实现图形用户界面...只是一个触发性的操作...   使用广播是需要几

Android学习之路-------广播接收器

前言 没想到离上一篇博文的时间已经有一个多星期了,时间真的不等人啊,在这里LP告诉你们一个道理,如果现在有谁正在看管理时间的书,那么请你们把这些书放下吧,看了也没有用,因为时间我们根本管不了,我们只能管自己,如果真的想管时间,错了,应该是珍惜时间的话,那么请你们要和时间做朋友,介绍一本书给大家看<和时间做朋友> 作者是 李笑来. 不说废话了,广播开始了 目录 什么是广播 广播的种类 怎么去使用这些广播 最安全的广播 什么是广播? 广播相信有上过学的人都知道,在学校里面都有那么一个大喇叭,通知大

ESP8266学习笔记6:ESP8266规范wifi连接操作

一.前言 我整理了从2015年至今关于ESP8266的学习笔记,梳理出来了开发环境.基础功能.进阶学习三大部分.方便自己和他人.可点此查看,欢迎交流. 之前在笔记4<ESP8266的SmartConfig>http://blog.csdn.net/iotisan/article/details/54849410中,做了smartconfig例程的測试. 这个例程是因为DEMO演示的,离商用还有段距离. 几周前,有网友就问我esp8266又一次上电无法自己主动连接之前配置的路由器.这确实是眼下D

Android框架中的广播机制

一.广播通过Intent发送出去 // 定义广播的意图过滤器 private String action = "com.xxx.demo.Broadcast.STATUS_CHANGED"; // 发送广播 Intent intent = new Intent(); intent.setAction(action); ServiceSimulation.this.sendBroadcast(intent); 二.定义接收该广播的BroadcaseReceiver类 1.继承自继承自an

android(eclipse)广播机制知识梳理(三)

1:分类:   标准广播:没有先后顺序,无法被截断   有序广播:又先后顺序,可以截断 2:接收广播:首先进行注册,注册的方式有静态注册和动态注册.也就是在代码中注册和在AndroidManifest中注册,并且一旦涉及到系统方面的关键性信息无论静态还是动态都要在manifest中声明权限: <users-permission andorid:name="android.permission.ACCESS_NETWORK_STATE"/>查询网络状态 <users-p

Android学习笔记之消息机制

Android的消息机制主要是指Handler的运行机制以及Handler所附带的MessageQueue和Looper的工作过程.   1.为什么要使用Handler? Android规定访问UI只能在主线程中进行,如果在子线程中访问UI,则会抛出异常.同时Android建议不能在主线程中进行耗时的操作,不然会导致程序无法响应即ANR.因此耗时的工作只能交给子线程去做,而子线程却不能直接访问UI,为了解决这个矛盾,Android提供了Handler.Handler的主要作用是将某个任务切换到某

Android学习之Handler消息传递机制

Android只允许UI线程修改Activity里的UI组件.当Android程序第一次启动时,Android会同时启动一条主线程(Main Thread),主线程主要负责处理与UI相关的事件,如用户的按键事件.屏幕绘图事件,并把相关的事件分发到对应的组件进行处理.所以,主线程通常又被称为UI线程. Android只允许UI线程修改Activity里的UI组件,这样会导致新启动的线程无法动态改变界面组件的属性值.但在实际的Android程序开发中,尤其是涉及动画的游戏开发中,需要让新启动的线程周

Android学习笔记之广播意图及广播接收者MyBroadcastReceiver、Broadcast

(1)第一种使用xml文件进行注册 布局文件,添加一个button点击的时候进行广播 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height