Android 开发技巧杂集
?
分类:?Android2010-12-07 18:40?351人阅读?评论(0)?收藏?举报
1.检查是否有网络连接
Java代码
1. public static boolean isNetworkAvailable(Context context) {
2. ConnectivityManager cm = (ConnectivityManager) context.getSystemService(
3. Context.CONNECTIVITY_SERVICE);
4. NetworkInfo info = cm.getActiveNetworkInfo();
5. return (info != null && info.isConnected());
6. }
public static boolean isNetworkAvailable(Context context) {
ConnectivityManager cm = (ConnectivityManager) context.getSystemService(
Context.CONNECTIVITY_SERVICE);
NetworkInfo info = cm.getActiveNetworkInfo();
return (info != null && info.isConnected());
}
2.全屏和无标题
Java代码
1. // 全屏 ( No Statusbar )
2. getWindow (). setFlags ( WindowManager . LayoutParams . FLAG _ FULLSCREEN ,
3. WindowManager . LayoutParams . FLAG _ FULLSCREEN );
4. // 无标题栏 ( No Titlebar )
5. requestWindowFeature ( Window . FEATURE _ NO _ TITLE );
// 全屏 ( No Statusbar )
getWindow (). setFlags ( WindowManager . LayoutParams . FLAG _ FULLSCREEN ,
WindowManager . LayoutParams . FLAG _ FULLSCREEN );
// 无标题栏 ( No Titlebar )
requestWindowFeature ( Window . FEATURE _ NO _ TITLE );
3.使用ViewStub延迟展开视图
Java代码
1. 1 ) 定义 ViewStub
2. < ViewStub android : id = "@+ id / stub _ import "
3. android : inflatedId ="@+ id / panel _ import "
4. android : layout ="@ layout / progress _ overlay "
5. android : layout _ width =" fill _ parent "
6. android:layout_height="wrap_content"
7. android:layout_gravity="bottom"/>
8. 2 )展开视图
9. findViewById(R.id.stub_import).setVisibility(View.VISIBLE);
10. // 或者 获取视图
11. View importPanel = ((ViewStub)
12. findViewById(R.id.stub_import)).inflate();
1 ) 定义 ViewStub
< ViewStub android : id = "@+ id / stub _ import "
android : inflatedId ="@+ id / panel _ import "
android : layout ="@ layout / progress _ overlay "
android : layout _ width =" fill _ parent "
android:layout_height="wrap_content"
android:layout_gravity="bottom"/>
2 )展开视图
findViewById(R.id.stub_import).setVisibility(View.VISIBLE);
// 或者 获取视图
View importPanel = ((ViewStub)
findViewById(R.id.stub_import)).inflate();
4.删除窗口背景
1) 编码实现
Java代码
1. public void onCreate(Bundle icicle){
2. super.onCreate(icicle);
3. setContentView(R.layout.mainview);
4. // 删除窗口背景
5. getWindow().setBackgroundDrawable(null);
6. ...
7. }
public void onCreate(Bundle icicle){
super.onCreate(icicle);
setContentView(R.layout.mainview);
// 删除窗口背景
getWindow().setBackgroundDrawable(null);
...
}
2 )自定义主题实现
Java代码
1. < resources>
2. < mce:style name="NoBackgroundTheme" parent="android:Theme">< !--
3. < item name="android:windowBackground">@null< /item>
4. -->< /mce:style>< style name="NoBackgroundTheme" parent="android:Theme" mce_bogus="1">< item name="android:windowBackground">@null< /item>< /style>
5. < /resources>
< resources>
< mce:style name="NoBackgroundTheme" parent="android:Theme">< !--
< item name="android:windowBackground">@null< /item>
-->< /mce:style>< style name="NoBackgroundTheme" parent="android:Theme" mce_bogus="1">< item name="android:windowBackground">@null< /item>< /style>
< /resources>
6.横竖屏切换时不重新加载 onCreate()
为了防止横竖屏切换时 Activity 重新加载 onCreate ,
只需要在 Activity 的配置文件里添加属性:
android:configChanges="orientation|keyboardHidden|navigation"
7.半透明主题
1.Resource source file location : res/values/styles.xml
< style name="myTranslucentTheme" parent="android:style/Theme.Translucent">
< item name="android:windowBackground">@drawable/bg< /item>
< /style>
其中 bg 为一张半透明图片的索引
2. 使用自定义半透明主题
AndroidManifest.xml
Java代码
1. < activity android:name=".WallpaperActivity"
2. android:label="@string/wallpaper_titile"
3. android:theme="@style/myTranslucentTheme">
4. < /activity>
< activity android:name=".WallpaperActivity"
android:label="@string/wallpaper_titile"
android:theme="@style/myTranslucentTheme">
< /activity>
8.获取Android手机上的图片和视频缩略图
大家都知道Android从1.5开始刚插入SD卡时系统会调用MediaScanner服务进行后台扫描,索引新的歌曲、图片和视频等信息,如果我们需要快速提取图片和视频缩略图可以直接访问 android.provider.MediaStore.Images.Thumbnails 和android.provider.MediaStore.Video.Thumbnails这两个数据库,即可查询出来缩略图
如何判断文件呢? 可以通过Cursor遍历数据库,对比INTERNAL_CONTENT_URI字段的值,这是一个Uri我们可以转成String,这里保存着Android手机SD卡上的多媒体文件完整路径,
有关具体的缩略图可以通过getThumbnail(ContentResolver cr, long origId, int kind, BitmapFactory.Options options) 或getThumbnail(ContentResolver cr, long origId, long groupId, int kind, BitmapFactory.Options options) 方法获取,这两种方法返回Bitmap类型,而缩略图的分辨率可以从HEIGHT和WIDTH两个字段提取,在Android上缩略图分为两种,通过读取 KIND字段来获得,分别为MICRO_KIND和MINI_KIND 分别为微型和迷你两种缩略模式,前者的分辨率更低。这样我们平时获取文件系统的某个图片预览时,可以直接调用系统缩略图,而不用自己重新计算。
最后Android123提示大家,缩略图保存在SD卡的DCIM目录,里面的.thumbnails是图片的,而.video_thumbnails是视频的,这两个文件夹为隐藏属性,一般的文件管理器都可以看到。
9.Android ANR介绍与避免
很多初入Android开发的网友可能发现ANR的字样,到底Android ANR是什么呢? 其实ANR就是Application Not Responding的全称,当某个应用处于长期假死状态时Android系统会弹出一个窗口上面写道,XXX is not responding给出两个按钮一个为force close一个为wait。
可能触发ANR的情况
1. 长时间的I/O处理,比如读写大文件,网络访问时造成的阻塞。
2. 执行耗时的运算,Android默认为超过5000ms即5秒开始弹出ANR窗口,某些应用可能首次执行时没有缓存十分耗时,可以通过Splash播放闪屏Logo等方式来延缓加载
3. Service和appWidget中也要注意多线程的使用,除非它和Activity工作在不同的进程。
避免ANR的方法
1. 单独开工作者线程,通过独立的Thread或使用类似AsyncTask的方式来处理耗时的内容。
2. 耗时的操作尽量分段处理,使用类似状态机的方法,类似Symbian的活动对象将一个复杂的事情,分段执行。
3. UI线程中不要处理过多的内容,比如将一个5MB的文本,让TextView去setText,要知道这种UI操作,没有什么好方法去解决的,所以Android123提示,遇到UI中需要执行复杂的操作,可以参考上面2提到的分段处理方式。
10.AsyncTask对比Thread加Handler
很多网友可能发现Android平台很多应用使用的都是AsyncTask,而并非Thread和Handler去更新UI,这里 Android123给大家说下他们到底有什么区别,我们平时应该使用哪种解决方案。从Android 1.5开始系统将AsyncTask引入到android.os包中,过去在很早1.1和1.0 SDK时其实官方将其命名为UserTask,其内部是JDK 1.5开始新增的concurrent库,做过J2EE的网友可能明白并发库效率和强大性,比Java原始的Thread更灵活和强大,但对于轻量级的使 用更为占用系统资源。Thread是Java早期为实现多线程而设计的,比较简单不支持concurrent中很多特性在同步和线程池类中需要自己去实现 很多的东西,对于分布式应用来说更需要自己写调度代码,而为了Android UI的刷新Google引入了Handler和Looper机制,它们均基于消息实现,有事可能消息队列阻塞或其他原因无法准确的使用。
Android开发网推荐大家使用AsyncTask代替Thread+Handler的方式,不仅调用上更为简单,经过实测更可靠一 些,Google在 Browser中大量使用了异步任务作为处理耗时的I/O操作,比如下载文件、读写数据库等等,它们在本质上都离不开消息,但是AsyncTask相比 Thread加Handler更为可靠,更易于维护,但AsyncTask缺点也是有的比如一旦线程开启即dobackground方法执行后无法给线程 发送消息,仅能通过预先设置好的标记来控制逻辑,当然可以通过线程的挂起等待标志位的改变来通讯,对于某些应用Thread和Handler以及 Looper可能更灵活。
11.android.os.Debug调试工具使用方法
在Android软件开发中最终的性能测试和调试显得至观重要,今天Android123和大家一起讨论下Google送给我们的android.os.Debug类,使用起来比较简单,我们先导入 import android.os.Debug这个包。
在需要开始跟踪的地方加入 Debug.startMethodTracing(“/sdcard/cwj”);
最终在停止调试的地方加入 Debug.stopMethodTracing();
最终在sdcard上生成的cwj文件我们可以用sdk ools中的traceview来查看运行的结果。
12.TextView多行本文滚动轻松实现
Android中我们为了实现文本的滚动可以在ScrollView中嵌入一个TextView,其实TextView自己也可以实现多行滚动的,毕竟ScrollView必须只能有一个直接的子类布局。只要在layout中简单设置几个属性就可以轻松实现
Java代码
1. < TextView
2. android:id="@+id/tvCWJ"
3. android:layout_width="fill_parent"
4. android:layout_height="wrap_content"
5. android:scrollbars="vertical" < !--垂直滚动条 -->
6. android:singleLine="false" < !--实现多行 -->
7. android:maxLines="15" < !--最多不超过15行 -->
8. android:textColor="#FF0000"
9. />
< TextView
android:id="@+id/tvCWJ"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:scrollbars="vertical" < !--垂直滚动条 -->
android:singleLine="false" < !--实现多行 -->
android:maxLines="15" < !--最多不超过15行 -->
android:textColor="#FF0000"
/>
当然我们为了让TextView动起来,还需要用到TextView的setMovementMethod方法设置一个滚动实例,代码如下
Java代码
1. TextView tvAndroid123 = (TextView)findViewById(R.id.tvCWJ);
2. tvAndroid123.setMovementMethod(ScrollingMovementMethod.getInstance()); // Android开发网提示相关的可以查看SDK中android.text.method分支了解更多
TextView tvAndroid123 = (TextView)findViewById(R.id.tvCWJ);
tvAndroid123.setMovementMethod(ScrollingMovementMethod.getInstance()); // Android开发网提示相关的可以查看SDK中android.text.method分支了解更多
12.Widget简单制作流程
1、在 OnUpdate()中 定义一个 Intent
Intent startActivityIntent = new Intent(context,WidgetLife.class);
2、实例化一个 PendingIntent
PendingIntent Pintent = PendingIntent.getActivity(context,0,startActivityIntent,0);
3、实例RemoteView
RemoteViews ActivityView = new RemoteViews(context.getPackageName(),R.layout.widget_layout);
4、Button 事件
ActivityView.setOnClickPendingIntent(R.id.Button,Pintent);
5、更新Widget
appWidgetManager.updateAppWidget(appWidgetIds,ActivityView);
12.对话框【Dialog】去除白色边框代码
边框, Dialog, Android, 对话框, 代码
使用样式文件,在values 目录下新建styles.xml文件,编写如下代码:
Java代码
1. < resources>
2. < mce:style name="dialog" parent="@android:style/Theme.Dialog">< !--
3. < item name="android:windowFrame">@null< /item>
4. < item name="android:windowIsFloating">true< /item>
5. < item name="android:windowIsTranslucent">false< /item>
6. < item name="android:windowNoTitle">true< /item>
7. < item name="android:background">@android:color/black< /item>
8. < item name="android:windowBackground">@null< /item>
9. < item name="android:backgroundDimEnabled">false< /item>
10.
11. -->< /mce:style>< style name="dialog" parent="@android:style/Theme.Dialog" mce_bogus="1"> < item name="android:windowFrame">@null< /item>
12. < item name="android:windowIsFloating">true< /item>
13. < item name="android:windowIsTranslucent">false< /item>
14. < item name="android:windowNoTitle">true< /item>
15. < item name="android:background">@android:color/black< /item>
16. < item name="android:windowBackground">@null< /item>
17. < item name="android:backgroundDimEnabled">false< /item>
18. < /style>
19. < /resources>
< resources>
< mce:style name="dialog" parent="@android:style/Theme.Dialog">< !--
< item name="android:windowFrame">@null< /item>
< item name="android:windowIsFloating">true< /item>
< item name="android:windowIsTranslucent">false< /item>
< item name="android:windowNoTitle">true< /item>
< item name="android:background">@android:color/black< /item>
< item name="android:windowBackground">@null< /item>
< item name="android:backgroundDimEnabled">false< /item>
-->< /mce:style>< style name="dialog" parent="@android:style/Theme.Dialog" mce_bogus="1"> < item name="android:windowFrame">@null< /item>
< item name="android:windowIsFloating">true< /item>
< item name="android:windowIsTranslucent">false< /item>
< item name="android:windowNoTitle">true< /item>
< item name="android:background">@android:color/black< /item>
< item name="android:windowBackground">@null< /item>
< item name="android:backgroundDimEnabled">false< /item>
< /style>
< /resources>
调用时,使用AlerDialog的接口类,Dialog 接口编写如下代码:
Java代码
1. Dialog dialog = new Dialog(SetActivity.this, R.style.dialog);
2. dialog.setContentView(R.layout.test);
3. dialog.show();