Android 常用知识列举

jopen 9年前
  1. 在Activity可见时进行页面刷新,即处于Activity栈顶,当然,这种刷新操作 可以在onStart,onResume,onRestart,onNewIntent+singleTask中,但最好的位置是onResume,其他方式可能会造成窗体泄露

  2. Service的两种启动方式,startService和bindService,根据启动方式的不同,当然也有一种称为复合方式startService+bindService,Service销毁的方式不同,startService可以做app退出后的后台服务,但bindService不行,startService+bindService也可以做后app退出后的后台服务,但app退出时必须unbind,反过来bindService+startService不能做app退出后的服务

  3. 建议在Activity增加一个变量activityIsActivity来判断当前Activity是否处于活动状态,Activity::onResume和Activity:onPause中改变其值,防止在无界面时发生窗体泄露问题。

  4. 在Activity的onWindowFocusChanged的方法中监听焦点的改变

  5. 使用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()替换成该空间

  6. dip转px的公式是 px = dip*scale+0.5f,scale是密度,当然,还可以使用  (int)TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_PX, 20, context.getResources().getDisplayMetrics());

  7. 获取DisplayMetrics的方式有2种,getWindow.getWindowManager.getDisplayMetrics(DisplayMetric dm),还有一种是context.getResources().getDisplayMetrics(),后者使用比较灵活,建议使用后者

  8. 自定义权限+引用+使用自定义权限的方式是,自定义<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>
  9. android:export表示该组件是否被跨进程调用,默认是false,android:windowSoftInputMode表示设置 键盘弹出UI布局的改变 以及定义键盘弹出状态,何时弹出等行为

  10. android:noHistory表示该组件不会在(最近打开列表中)显示,android:configChanges表示当发生指定的改变时,Activity程序不会重新启动,响应的变化也会通过onConfigurationChanged中得到,android:screenOriention表示Activity应该处于何种屏幕状态,android:lancheMode是指定创建模式

  11. 强制检测跨进程调用的权限问题

    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();  }


  12. <use-library>生命需要的连接共享库,<use-feature>生命app所需要的硬件环境支持,如支持蓝牙等,否则app将安装失败。

  13. android:clearTaskOnLaunch和android:finishOnTaskLauch的区别是,前者清楚自身以外的Activity,后者清除转入后台的Activity Task。后者比较常用。

  14. 系统会为每一个app分配一个虚拟机进程,因此不想jvm所有的应用共享同一个虚拟机进程

  15. 使用LocalBroadcastReceiver或者myView.getHandler进行消息队列方式的更新,自定义Handler时请以静态方式继承Handler,否则可能因为Handler持有的Activity无法销毁,因为Handler本身是持有静态对象,他的生命周期和app相同,因此为了让Activity及时销毁,必须静态继承 public static class MyHandler extends Handler

    来自:http://my.oschina.net/ososchina/blog/378571