android开发中代码片段集合

本文中所提及的代码往往只有一行或短短几行就可能完成某种效果和功能,当我们不知道答案的时候,通常会花费了我们很多时间去google或baidu来寻找。这里对遇到的问题作个记录整理下,方便以后的查找,同时也希望能帮到你,当然更多的可能是你已经知道答案了,下面的对你来说 so easy   


1.   如何设置通知栏下拉不可用  

        有时候在一个界面不想让通知栏下拉的消息就是这个代码了, NotificaionManager里的一个方法。  


[java] view plaincopyprint?NotificationMgr.getDefault().getStatusBarMgr().enableExpandedView(false);       

     NotificationMgr.getDefault().getStatusBarMgr().enableExpandedView(false);     

2 . 设置actionBar的图标在屏幕底部显示  

        android 3.0版本增加的功能,类似menu的作用,在官方的例子中,图标都是在屏幕顶部的,前提是你上面有足够的空间,如果想把actionBar的图标放下屏幕底部就要用下面的代码了 ,在Androidmanifest.xml文件中activity标签中添加  

[java] view plaincopyprint?android:uiOptions="splitActionBarWhenNarrow"    

    android:uiOptions="splitActionBarWhenNarrow"  
3 . 代码设置文本点击按下颜色变化  
[html] view plaincopyprint?<?xml version="1.0" encoding="utf-8"?>    
<selector xmlns:android="http://schemas.android.com/apk/res/android">    
    <item android:state_pressed="true"    
      android:color="#ffff0000"/> <!-- pressed -->    
    <item android:state_focused="true"    
      android:color="#ff0000ff"/> <!-- focused -->    
    <item android:color="#ff000000"/> <!-- default -->    
 </selector>   //www.sctarena.com 

    <?xml version="1.0" encoding="utf-8"?>  
    <selector xmlns:android="http://schemas.android.com/apk/res/android">  
        <item android:state_pressed="true"  
          android:color="#ffff0000"/> <!-- pressed -->  
        <item android:state_focused="true"  
          android:color="#ff0000ff"/> <!-- focused -->  
        <item android:color="#ff000000"/> <!-- default -->  
     </selector>         上面代码是一个选择器,通常情况我们都在布局文件中添加这样的代码android:background = "@drawable/选择器的文件名" 来实现背景或颜色切换的,可要是用对应功能的代码实现是什么样子呢?  
[java] view plaincopyprint?    <STRONG>ColorStateList.java 这个类 </STRONG>    
    Button btn=(Button)findViewById(R.id.btn);    
    Resources resource=(Resources)getBaseContext().getResources();    
       ColorStateList csl=(ColorStateList)resource.getColorStateList(R.color.button_text);    
       if(csl!=null){    
       btn.setTextColor(color_state_list);//设置按钮文字颜色     
}    

    ColorStateList.java 这个类   
    Button btn=(Button)findViewById(R.id.btn);  
    Resources resource=(Resources)getBaseContext().getResources();  
       ColorStateList csl=(ColorStateList)resource.getColorStateList(R.color.button_text);  //成都IT培训
       if(csl!=null){  
       btn.setTextColor(color_state_list);//设置按钮文字颜色  
}         这里要提一下 setTextColor这个方法的参数类型是int,而R.drawable.选择器的文件名也是个int型变量,代码编译不会报错,但不会起作用。如果你是动态的生成一些button或textView而又不能使用布局文件,你会很想念这个ColorStateList.java 这个类的  




4. setContentView和inflate区别:  
setContentView()一旦调用, layout就会立刻显示UI;而inflate只会把Layout形成一个以view类实现成的对象,有需要时再用setContentView(view)显示出来  




5. 美化我们的seekbar  

    换了图片,滑块图片只显示一半怎么办? ,看下面的代码和代码注释你会找到答案的  


[html] view plaincopyprint?<SeekBar android:id= "@+id/song_progress"    
    android:thumb="@drawable/sound_progressbar_slider"   //   滑块的图片    
    android:progressDrawable ="@drawable/sound_seekbar_img"     //进度条的图片设置,对应的是一个xml文件,功能就是selector的效果    
    android:thumbOffset="16dip"                          //   这个保证滑块中心和进度条首尾两端的中心点是一致的    
    android:paddingLeft="16dip"                          //   保证滑块显示全部,没有它滑块在首尾两端只会显示一半,右一半,左一半。    
    android:paddingRight="16dip"                         //   同上    
    android:layout_gravity="center_horizontal"  
    android:layout_width="284dip"                        //   进度条的宽度加上滑块的宽度,可能需要微调下    
    android:minHeight="33dip"                            //   高度要和滑块图片的高度等高,最好这样做,    
    android:maxHeight="33dip"                            //   同上    
    android:layout_height="33dip" />    

 <SeekBar android:id= "@+id/song_progress"  
     android:thumb="@drawable/sound_progressbar_slider"   //   滑块的图片  
     android:progressDrawable ="@drawable/sound_seekbar_img"     //进度条的图片设置,对应的是一个xml文件,功能就是selector的效果  
     android:thumbOffset="16dip"                          //   这个保证滑块中心和进度条首尾两端的中心点是一致的  
     android:paddingLeft="16dip"                          //   保证滑块显示全部,没有它滑块在首尾两端只会显示一半,右一半,左一半。  
     android:paddingRight="16dip"                         //   同上  
     android:layout_gravity="center_horizontal"  
     android:layout_width="284dip"                        //   进度条的宽度加上滑块的宽度,可能需要微调下  
     android:minHeight="33dip"                            //   高度要和滑块图片的高度等高,最好这样做,  
     android:maxHeight="33dip"                            //   同上  
     android:layout_height="33dip" />             
6  两张图片叠加成一张图   

     这个代码也是之前在网上搜到的,只是实在找不到原始出处了。当然还有别的方法实现叠图的效果,这个经测试验证可用,仅此而已。  


[java] view plaincopyprint?Bitmap bitmap1 = ((BitmapDrawable) getResources().getDrawable( R.drawable.ic_default_slide)).getBitmap();    
Bitmap bitmap2 = ((BitmapDrawable) getResources().getDrawable(   R.drawable.ic_slide_player)).getBitmap();    
    
Drawable[] array = new Drawable[2];    
array[0] = new BitmapDrawable(bitmap1);    
array[1] = new BitmapDrawable(bitmap2);    
LayerDrawable la = new LayerDrawable(array);  
// 其中第一个参数为层的索引号,后面的四个参数分别为left、top、right和bottom     
la.setLayerInset(0, 0, 0, 0, 0);    
la.setLayerInset(1, 20, 20, 20, 20);    
im.setImageDrawable(la);    

        Bitmap bitmap1 = ((BitmapDrawable) getResources().getDrawable( R.drawable.ic_default_slide)).getBitmap();  
        Bitmap bitmap2 = ((BitmapDrawable) getResources().getDrawable(   R.drawable.ic_slide_player)).getBitmap();  

        Drawable[] array = new Drawable[2];  
        array[0] = new BitmapDrawable(bitmap1);  
        array[1] = new BitmapDrawable(bitmap2);  
        LayerDrawable la = new LayerDrawable(array);  
        // 其中第一个参数为层的索引号,后面的四个参数分别为left、top、right和bottom  
        la.setLayerInset(0, 0, 0, 0, 0);  
        la.setLayerInset(1, 20, 20, 20, 20);  
        im.setImageDrawable(la);  


  7     按XY轴比例缩放图片          


[html] view plaincopyprint?ImageView.ScaleType.FIT_XY缩放图片使用XY    
ImageView.ScaleType.center:图片位于视图中间,但不执行缩放。    
ImageView.ScaleType其余的值,感觉没有前两个常用           
    ImageView.ScaleType.CENTER_CROP 按统一比例缩放图片(保持图片的尺寸比例)便于图片的两维(宽度和高度)等于或者大于相应的视图的维度    
    ImageView.ScaleType.CENTER_INSIDE按统一比例缩放图片(保持图片的尺寸比例)便于图片的两维(宽度和高度)等于或者小于相应的视图的维度    
    ImageView.ScaleType.FIT_CENTER缩放图片使用center    
    I mageView.ScaleType.FIT_END缩放图片使用END    
    ImageView.ScaleType.FIT_START缩放图片使用START    
    ImageView.ScaleType.MATRIX当绘制时使用图片矩阵缩放   

猜你喜欢

转载自biandroid.iteye.com/blog/1882489
今日推荐