Android 常用知识列举
-
在Activity可见时进行页面刷新,即处于Activity栈顶,当然,这种刷新操作 可以在onStart,onResume,onRestart,onNewIntent+singleTask中,但最好的位置是onResume,其他方式可能会造成窗体泄露
-
Service的两种启动方式,startService和bindService,根据启动方式的不同,当然也有一种称为复合方式startService+bindService,Service销毁的方式不同,startService可以做app退出后的后台服务,但bindService不行,startService+bindService也可以做后app退出后的后台服务,但app退出时必须unbind,反过来bindService+startService不能做app退出后的服务
-
建议在Activity增加一个变量activityIsActivity来判断当前Activity是否处于活动状态,Activity::onResume和Activity:onPause中改变其值,防止在无界面时发生窗体泄露问题。
-
在Activity的onWindowFocusChanged的方法中监听焦点的改变
-
使用InputMethodManager 退出键盘最灵活的方式是
InputMethodManager imm = (InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE); boolean isOpen=imm.isActive();//isOpen若返回true,则表示输入法打开 if(isOpen) { imm.hideSoftInputFromWindow(MainActivity.this.getCurrentFocus().getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS); //(WidgetSearchActivity是当前的Activity) }
当然,如果页面只会有一个可以启动键盘的EditText,可直接将MainActivity.this.getCurrentFocus()替换成该空间
-
dip转px的公式是 px = dip*scale+0.5f,scale是密度,当然,还可以使用 (int)TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_PX, 20, context.getResources().getDisplayMetrics());
-
获取DisplayMetrics的方式有2种,getWindow.getWindowManager.getDisplayMetrics(DisplayMetric dm),还有一种是context.getResources().getDisplayMetrics(),后者使用比较灵活,建议使用后者
-
自定义权限+引用+使用自定义权限的方式是,自定义<permission android:name="自定义权限" android:protected="根据安全等级设置,如果保密性较高,使用签名方式" />,然后引用<use-permission android:name="自定义权限" />,使用自定义权限 如下
<receiver android:name=".SmsBroadCastReceiver" android:export="false" android:permission="自定义权限"> <intent-filter android:priority="20"> <action android:name="android.provider.Telephony.SMS_RECEIVED"/> </intent-filter> </receiver>
-
android:export表示该组件是否被跨进程调用,默认是false,android:windowSoftInputMode表示设置 键盘弹出UI布局的改变 以及定义键盘弹出状态,何时弹出等行为
-
android:noHistory表示该组件不会在(最近打开列表中)显示,android:configChanges表示当发生指定的改变时,Activity程序不会重新启动,响应的变化也会通过onConfigurationChanged中得到,android:screenOriention表示Activity应该处于何种屏幕状态,android:lancheMode是指定创建模式
-
强制检测跨进程调用的权限问题
public boolean isEnable(){ mContext.enforceCallingOrSelfPermission(android.Manifest.permission.WAKE_LOCK,"you donot have the wake_lock permission"); Log.d("pid="+Binder.getCallingPid()+",uid="+Binder.getCallingUid()); return isEnableInternal(); }
-
<use-library>生命需要的连接共享库,<use-feature>生命app所需要的硬件环境支持,如支持蓝牙等,否则app将安装失败。
-
android:clearTaskOnLaunch和android:finishOnTaskLauch的区别是,前者清楚自身以外的Activity,后者清除转入后台的Activity Task。后者比较常用。
-
系统会为每一个app分配一个虚拟机进程,因此不想jvm所有的应用共享同一个虚拟机进程
-
使用LocalBroadcastReceiver或者myView.getHandler进行消息队列方式的更新,自定义Handler时请以静态方式继承Handler,否则可能因为Handler持有的Activity无法销毁,因为Handler本身是持有静态对象,他的生命周期和app相同,因此为了让Activity及时销毁,必须静态继承 public static class MyHandler extends Handler
来自:http://my.oschina.net/ososchina/blog/378571