无聊的前言:
又是艰苦卓绝的一周,我这种人又想放弃了,真是无语。之前看了视频还以为挺简单,周五也做了一点点,自信满满留到周日下午完成。于是周六和朋友出去,聊了国家和民族在社会主义初级阶段的矛盾(6不6),以及自身的发展问题,有点无奈,感觉自己人生选择变少了,眼界窄的可怕。。。然后周日下午开始写作业,结果各种BUG。于是又想放弃,结果老师一眼看出缺个非空判断语句,这种问题也是能搞死人的。。。下周晚上不能玩了,要看文档了
Service:服务,可以实现比如音乐播放之类的后台功能
首先继承
public class MusicService extends Service在ManiFest.xml中添加申明
<service android:name=".MusicService"/>接着在res中添加raw文件夹,用于存放音频文件(英文小写)
服务启动方法有二:
-
1.start启动方式
1@Override public void onCreate() { super.onCreate(); mMediaPlayer = MediaPlayer.create(this,R.raw.libai); }
2
@Override public int onStartCommand(Intent intent, int flags, int startId) { mMediaPlayer.start(); return START_NOT_STICKY; }
3
@Override public void onDestroy() { mMediaPlayer.stop(); super.onDestroy(); }
大致生命周期:onCreate()->onStartCommand->onDestroy()
-
2.bind方式(比作桥梁)
1.Service中新建内部类,返回MusicService给Activity中的ServiceConnectionpublic class LocalBinder extends Binder { MusicService getService(){ return MusicService.this; } }
2.暂存Binder中,Binder实现了IBinder接口,故实例化IBinder对象来绑定service
private IBinder mIBinder = new LocalBinder();
3.在Service类的默认方法中得到IBinder对象
@Nullable @Override public IBinder onBind(Intent intent) { return mIBinder; }
4.此处传入一个mServiceConnection
bindService(new Intent(MainActivity.this, MusicService.class), mServiceConnection, BIND_AUTO_CREATE);
5.写一个连接带两个方法(有点绕)
private ServiceConnection mServiceConnection = new ServiceConnection() { private MusicService mMusicService; @Override public void onServiceConnected(ComponentName name, IBinder service) { MusicService.LocalBinder localBinder= (MusicService.LocalBinder) service; mMusicService = localBinder.getService(); } @Override public void onServiceDisconnected(ComponentName name) { } };
6.最后unbindService
unbindService(mServiceConnection);
Broadcast Receiver广播接收器
1、四大组件之一:广播(通知消息)接收器 –要想到在Manifest中注册
2、系统使用了很多广播:通知时间改变(闹钟才会响)、电池电量变低、拍摄了照片、改变了语言
3、没有用户界面。
4、只负责向所有在Manifest里的注册者发送广播,需要这个广播的人去接收它。
BroadcastReceiver的两种注册方式:
-
1.静态注册
<receiver android:name=".TestBroadcastReceiver"> <intent-filter> <action android:name="com.example.test.broadcast"/> </intent-filter> </receiver>
-
2.动态注册,在onStart方法中注册,在onStop方法中反注册
@Override protected void onStart() { super.onStart(); /* 动态注册广播*/ //根据action里的android:name过滤广播。 IntentFilter intentFilter = new IntentFilter(); intentFilter.addAction(COM_EXAMPLE_TEST_BROADCAST); registerReceiver(mTestBroadcastReceiver, intentFilter); } @Override protected void onStop() { super.onStop(); unregisterReceiver(mTestBroadcastReceiver); }
两者的区别:静态注册的广播一直有效,动态注册的广播需要反注册掉,不然注册在内存里,会不断的消耗内存,所以常用动态注册。
如何接受广播 onReceive方法
-
MainActivity类
@Override public void onClick(View view) { /* 发送广播 */ Intent intent = new Intent(MainActivity.this,TestBroadcastReceiver.class); //只发给action为COM_EXAMPLE_TEST_BROADCAST intent.setAction(COM_EXAMPLE_TEST_BROADCAST); intent.putExtra("toast", "this is a toast of broadcast"); sendBroadcast(intent); }
-
BroadcastReceiver类
public class TestBroadcastReceiver extends BroadcastReceiver { /* 接收广播、处理数据 */ @Override public void onReceive(Context context, Intent intent) { if (intent != null){ //判断字符串是否相等TextUtils.equals(). if (TextUtils.equals(intent.getAction(),MainActivity.COM_EXAMPLE_TEST_BROADCAST)){ String toastString = intent.getStringExtra("toast"); Toast.makeText(context,toastString,Toast.LENGTH_SHORT).show(); } } } }
BroadcastReceiver的生命周期:Register – SendBroadcast – onReceive – unRegister
Widget安卓桌面显示插件
以下内容基本摘抄自上面这个博客,因为写的很好且详细,所以推荐直接看这个,自己这里只介绍一部分内容
App Widget是应用程序窗口小部件(Widget)是微型的应用程序视图,它可以被嵌入到其它应用程序中(比如桌面)并接收周期性的更新。你可以通过一个App Widget Provider来发布一个Widget。官方文档地址:http://developer.android.com/guide/topics/appwidgets/index.html
这里涉及到两个方面的内容:AppWidgetProvider类和appwidget-provider标签;-
1、appwidget-provider标签:定义桌面widget的大小,初始状态等等信息
android:minWidth : 最小宽度 android:minHeight : 最小高度 android:updatePeriodMillis : 更新widget的时间间隔(ms),"86400000"为1个小时 android:previewImage : 预览图片 android:initialLayout : 加载到桌面时对应的布局文件 android:resizeMode : widget可以被拉伸的方向。horizontal表示可以水平拉伸,vertical表示可以竖直拉伸 android:widgetCategory : widget可以被显示的位置。home_screen表示可以将widget添加到桌面,keyguard表示widget可以被添加到锁屏界面。 android:initialKeyguardLayout : 加载到锁屏界面时对应的布局文件
2、AppWidgetProvider类:
上面我们通过appwidget-provider标签就可以得到初始化的布局,视图等,但我们的widget要实时更新怎么办,要响应用户操作怎么办,这就需要额外的类来辅助处理了,这个类就是AppWidgetProvider。
由于AppWidgetProvider要接收到当前widget的状态(是否被添加,是否被删除等),所以要接收通知,必然是派生自BroadcastReceiver。
AppWidgetProvider中的广播处理函数如下:(根据不同的使用情况,重写不同的函数)
onUpdate():
在3种情况下会调用OnUpdate()。onUpdate()是在main线程中进行,因此如果处理需要花费时间多于10秒,处理应在service中完成。(第二篇会讲为什么还要有service)
(1)在时间间隔到时调用,时间间隔在widget定义的android:updatePeriodMillis中设置;
(2)用户拖拽到主页,widget实例生成。无论有没有设置Configure activity,我们在Android4.4的测试中,当用户拖拽图片至主页时,widget实例生成,会触发onUpdate(),然后再显示activity(如果有)。这点和资料说的不一样,资料认为如果设置了Configure acitivity,就不会在一开始调用onUpdate(),而实验显示当实例生成(包括创建和重启时恢复),都会先调用onUpate()。在本例,由于此时在preference尚未有相关数据,创建实例时不能有效进行数据设置。
(3)机器重启,实例在主页上显示,会再次调用onUpdate()
onDeleted(Context, int[]):
当 widget 被删除时被触发。
onEnabled(Context):
当第1个 widget 的实例被创建时触发。也就是说,如果用户对同一个 widget 增加了两次(两个实例),那么onEnabled()只会在第一次增加widget时触发。
onDisabled(Context):
当最后1个 widget 的实例被删除时触发。
onReceive(Context, Intent):
在接收到广播时,调用。
Webview
网页显示器,显示网页、解析网页、加载网页。
参考:
http://blog.csdn.net/sinat_16640839/article/details/50976429
http://blog.csdn.net/harvic880925/article/details/41445407