欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

ImageButton自定義按鈕的按下效果的高效實現方

系統 1933 0
通常情況下,我們可以采用如下方式實現:
    <?xml version="1.0" encoding="UTF-8"?>    
<selector xmlns:android="http://schemas.android.com/apk/res/android">    
    <item           android:state_pressed="false"  android:drawable="@drawable/button_add" />    
    <item           android:state_pressed="true"   android:drawable="@drawable/button_add_pressed" />    
    <item           android:state_focused="true"    android:drawable="@drawable/button_add_pressed" />    
<item           android:drawable="@drawable/button_add" />    
</selector> 
  

把這個文件放在drawable目錄下面。命名為button_add_x.xml
使用的時候:
    
<ImageButton    
                        android:id="@+id/ImageButton"    
                        android:layout_width="wrap_content"    
                        android:layout_height="wrap_content"    
                        android:background="#00000000"    
                        android:src="@drawable/button_add_x" /> 

  

這樣的實現過程雖然通用性好,但是很麻煩,一個按鈕實現效果需要多張圖片甚至再加一個布局…
那一個游戲要是有幾百個按鈕怎么辦呢?
于是:以下代碼被醞釀出來了:
    
/**  
   * 按下這個按鈕進行的顏色過濾  
   */  
  public final static float[] BT_SELECTED=new float[] {    
      2, 0, 0, 0, 2,    
      0, 2, 0, 0, 2,    
      0, 0, 2, 0, 2,    
      0, 0, 0, 1, 0 };   
     
  /**  
   * 按鈕恢復原狀的顏色過濾  
   */  
  public final static float[] BT_NOT_SELECTED=new float[] {    
      1, 0, 0, 0, 0,    
      0, 1, 0, 0, 0,    
      0, 0, 1, 0, 0,    
      0, 0, 0, 1, 0 };   
     
  /**  
   * 按鈕焦點改變  
   */  
  public final static OnFocusChangeListener buttonOnFocusChangeListener=new OnFocusChangeListener() {   
     
  @Override  
  public void onFocusChange(View v, boolean hasFocus) {   
   if (hasFocus) {   
    v.getBackground().setColorFilter(new ColorMatrixColorFilter(BT_SELECTED));   
    v.setBackgroundDrawable(v.getBackground());   
   }   
   else  
   {   
    v.getBackground().setColorFilter(new ColorMatrixColorFilter(BT_NOT_SELECTED));   
     v.setBackgroundDrawable(v.getBackground());   
   }   
  }   
 };   
    
  /**  
   * 按鈕觸碰按下效果  
   */  
 public final static OnTouchListener buttonOnTouchListener=new OnTouchListener() {   
  @Override  
  public boolean onTouch(View v, MotionEvent event) {   
   if(event.getAction() == MotionEvent.ACTION_DOWN){   
    v.getBackground().setColorFilter(new ColorMatrixColorFilter(BT_SELECTED));   
    v.setBackgroundDrawable(v.getBackground());   
    }   
    else if(event.getAction() == MotionEvent.ACTION_UP){   
     v.getBackground().setColorFilter(new ColorMatrixColorFilter(BT_NOT_SELECTED));   
     v.setBackgroundDrawable(v.getBackground());   
    }   
   return false;   
  }   
 };   
    
 /**  
  * 設置圖片按鈕獲取焦點改變狀態(tài)  
  * @param inImageButton  
  */  
 public final static void setButtonFocusChanged(View inView)   
 {   
  inView.setOnTouchListener(buttonOnTouchListener);   
  inView.setOnFocusChangeListener(buttonOnFocusChangeListener);   
 }  

  

使用時,調用方法public final static void setButtonFocusChanged(View inView)即可。
【原理】
利用Drawable類的setColorFilter方法對圖片進行顏色偏移過濾處理。

以下為效果圖,登陸按鈕此時為獲取焦點狀態(tài)。
ImageButton自定義按鈕的按下效果的高效實現方法(非一般)
代碼可以適當修改實現3個不同的狀態(tài):正常,獲取焦點,點擊。

http://blog.csdn.net/sytzz/article/details/5673662

ImageButton自定義按鈕的按下效果的高效實現方法(非一般)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: av网址在线 | 好大好硬好长好爽a网站 | 欧美日韩在线免费观看 | www日韩免费高清视频 | 欧美日韩综合精品 | 亚洲高清一区二区三区 | 欧美黑人激情 | 亚洲欧美日韩中文字幕久久 | 免费一级毛片在线播放视频 | 二级黄绝大片中国免费视频 | 香蕉久久网 | 波多野结衣的一级片 | 亚洲成人福利在线 | 亚洲欧美综合人成野草 | 国产一区二区免费 | 日本在线看| 色精品 | 92午夜影院 | 夜夜爱网站 | 欧美日韩视频在线 | 国产成人黄网在线免 | 午夜福利国产在线观看1 | a级片在线视频 | 久久久国产精品免费观看 | 成人精品国产 | 亚洲第一视频 | 一级片视频网站 | 成人在线观看免费视频 | 国产高清精品一区 | 亚洲综合图片色婷婷另类小说 | 午夜免费| 国产亚洲欧洲国产综合一区 | 国产第113页 | www.777色| 国产四区 | 免费亚洲视频在线观看 | 国产色视频一区 | 久久亚洲国产成人亚 | 亚洲免费在线看 | 毛片链接 | 日本免费一区二区三区视频 |