欧美三区_成人在线免费观看视频_欧美极品少妇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 | 日韩在线视频在线 | 亚洲一区色 | 精品视频在线免费看 | 国产精品毛片无码 | aaaaaa毛片| 亚洲综合国产 | 奇米影视小说 | 久草视频手机在线观看 | 特黄特色的大片观看免费视频 | 99热免费精品 | 国产精品视频免费观看 | 九二淫黄大片看片 | 欧美日韩一区二区三在线 | 丰满岳妇乱一区二区三区 | 亚洲 欧美 日韩在线 | 精品久久久久久久久久 | 日本中文字幕在线播放 | 欧美极品在线观看 | 日韩黄色网 | 色婷婷亚洲 |