`

ImageButton自定义按钮的按下效果的高效实现方法(非一般)

阅读更多
通常情况下,我们可以采用如下方式实现:
<?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;   
  }   
 };   
    
 /**  
  * 设置图片按钮获取焦点改变状态  
  * @param inImageButton  
  */  
 public final static void setButtonFocusChanged(View inView)   
 {   
  inView.setOnTouchListener(buttonOnTouchListener);   
  inView.setOnFocusChangeListener(buttonOnFocusChangeListener);   
 }  

使用时,调用方法public final static void setButtonFocusChanged(View inView)即可。
【原理】
利用Drawable类的setColorFilter方法对图片进行颜色偏移过滤处理。

以下为效果图,登陆按钮此时为获取焦点状态。

代码可以适当修改实现3个不同的状态:正常,获取焦点,点击。

http://blog.csdn.net/sytzz/article/details/5673662
  • 大小: 42.6 KB
分享到:
评论
2 楼 shencaifeixia 2011-10-20  
不错,谢了,我想要和系统一样的黄色,而不是白色,继续学习
1 楼 进阶兄 2011-09-06  
多谢,受益了

相关推荐

    android自定义按钮效果(两种方法)

    利用这些事件,我们可以在代码中动态更改按钮的背景图片,从而实现按下效果。 #### 实现步骤: 1. **创建背景图片资源**:首先,你需要准备两组图片资源,一组用于表示按钮正常状态下的外观,另一组用于表示按钮被...

    wince ppc 按钮控件 自定义按钮 ImageButton

    在这里,你需要使用Graphics对象来绘制图像和按钮状态(如鼠标悬停或按下状态)的细节。 3. 处理鼠标和键盘事件:为了实现交互性,你需要覆盖或添加处理MouseEnter、MouseLeave、MouseDown、MouseUp和Click等事件的...

    图片按钮ImageButton

    通过这样的实现,`ImageButton`控件就能够根据按钮的大小动态调整图像,使得无论按钮尺寸如何变化,图像都能充满整个按钮,提供一致的视觉效果。 标签中的"C# WinForm"表明这是在Windows Forms框架下使用C#编程语言...

    Android下实现win8风格的imageButton

    "Android下实现win8风格的imageButton"这一主题旨在教你如何在Android应用中创建具有Windows 8特色的弹性回弹效果的ImageButton。这种效果使得按钮在被触摸时能够产生视觉上的动态反馈,提升用户体验。 首先,要...

    QT按钮类的美化

    通过以上步骤,我们可以创建出与项目风格相匹配的、具有独特视觉效果的自定义按钮。在实际开发中,根据项目的具体需求,可能还需要处理更多的事件,实现更复杂的交互和动画效果。QT提供的强大功能和灵活性,使开发者...

    安卓Android源码——ImageButton.rar

    开发者可以通过继承 `ImageButton` 并重写相关方法来自定义自己的 `ImageButton`,例如自定义点击效果、图像动画等。 7. **无障碍功能** 考虑到无障碍性,`ImageButton` 的文字描述(`android:contentDescription...

    delphi6-7 控件ImageButton

    `ImageButton`控件在Delphi的`VCL`(Visual Component Library)库中属于`TButton`类的一个变体,因此它继承了许多按钮的基本属性和方法。`ImageButton`控件的主要特点是它可以显示一个图像,当用户点击时,就像普通...

    android exoplayer 自定义界面,播放器

    在这个项目中,我们将探讨如何自定义ExoPlayer的界面,实现横竖屏切换以及进度条拖动快进的功能。 首先,了解ExoPlayer的基本结构是非常重要的。ExoPlayer由多个组件组成,包括Renderer(渲染器)、DataSource...

    ImageButton

    同时,可以使用`android:background`属性设置按钮的背景,这通常用于设置按下状态时的图像。通过设置`android:onClick`属性,可以关联一个点击事件处理方法。 2. **事件监听**: 对于`ImageButton`的点击事件,...

    自定义控件书籍

    ### 自定义控件书籍知识点概览 #### 一、Android控件基本介绍 **1.1 Android 控件基本概述** Android 提供了丰富的内置控件,涵盖了文本输入、按钮交互、图像展示等多个方面,但有时候这些标准控件无法完全满足...

    应用源码之ImageButton.zip

    `ImageButton`与`ImageView`的主要区别在于,`ImageButton`允许用户设置背景,通常用于创建具有可点击效果的图像按钮。在XML布局文件中,我们可以通过`&lt;ImageButton&gt;`标签来声明它,并通过`android:src`属性设置...

    图文按钮的源代码资源

    本文将深入探讨图文按钮的设计原理、实现方法以及在不同平台上的应用。 1. 设计原则: - **一致性**:图文按钮的设计应与整体应用程序或网站的样式保持一致,以提供一致的用户体验。 - **可识别性**:图像应该...

    WPF 自定义控件

    `ImageButton`是将图像与按钮功能结合的自定义控件。我们可以通过以下步骤创建它: #### 步骤1:定义新类 首先,我们需要创建一个新的类,继承自`Button`类。在C#代码中,这可能看起来像这样: ```csharp public ...

    Android自定义UI模版

    在Android应用开发中,自定义UI模板是一种常见的实践,它能极大地提高开发效率,保持应用界面的一致性。...在实际工作中,我们应该积极推广和使用这样的自定义UI组件,以实现更高效、更规范的Android应用开发。

    Android开发技巧总汇(3).pdf

    7. **titleBar高级实现方法**:标题栏(titleBar)是应用界面的重要组成部分,文档介绍了如何进行高级定制,使标题栏更具美感和功能,比如添加自定义按钮或者动画效果。 8. **保存数据的四种方法**:Android提供了...

    Android开发技巧汇总_C[参照].pdf

    10. **ImageButton按下时的动画效果**:为了增加触觉反馈,开发者可以为ImageButton添加按下时的动画效果。这通常通过设置`android:background`属性为一个包含多种状态的`selector`资源来实现。 以上是Android开发...

    Qt on Android 示例程序

    这个示例可能涉及到了对 `QLabel` 的继承和重写绘制方法,以实现自定义的动画效果。 8. **日志记录:simplelog** 日志记录在软件开发中非常重要,`simplelog` 可能演示了如何在 Qt 应用中实现日志系统,包括记录...

    Android游戏开发20回合

    - **实现长按逻辑**:通过监听按钮的状态变化(按下与抬起),并在按下状态下周期性地检查是否满足长按条件。当满足条件时,通过`mListener`回调接口通知外部调用者进行相应的操作。 #### 二、View和SurfaceView 这...

    ASP.net技术中常见问题详细解答

    若需实现 ImageButton 在鼠标悬停时更换图片的效果,可以通过 JavaScript 的 `onmouseover` 和 `onmouseout` 事件来完成。下面是一个示例: ```html &lt;asp:ImageButton ID="ImageButton1" runat="server" ...

    Pro Android Graphics - Wallace Jackson.pdf

    本章可能会介绍如何通过继承和扩展ImageButton类来创建具有多种状态的自定义按钮控件,以及如何处理按钮的不同状态(如按下、选中、禁用等)。 第10章:使用9-Patch图像技术创建可伸缩的图像元素。9-Patch图像是一...

Global site tag (gtag.js) - Google Analytics