2

我想让用户在单击文本字段时感觉就像我们单击按钮时一样,并且在释放按钮后它会在很短的时间内变为橙色并闪烁并再次变成它的第一种颜色。当我点击它时效果很好,但没有出现颜色闪烁。

布局文件

<TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/button5"
        android:layout_below="@+id/button5"
        android:layout_marginLeft="35dp"
        android:layout_marginTop="28dp"
        android:clickable="true"
        android:onClick="onClick"
        android:text="Click Me"
        android:textAppearance="?android:attr/textAppearanceLarge" />

主活动代码

textV.setOnClickListener(new OnClickListener() {

    @Override
            public void onClick(View view) {
        startActivity(new Intent("com.DRMS.help"));
            }
        }); 
4

6 回答 6

3

您可以使用OnTouchListener ,也可以使用选择器。

textV.setOnTouchListener(new OnTouchListener() {

@Override
public boolean onTouch(View v, MotionEvent event) {
    if (event.getAction() == MotionEvent.ACTION_DOWN) {
            // change color
    }
    else if (event.getAction() == MotionEvent.ACTION_UP) {
            // set to normal color
    }

    return true;
}
});

编辑:

您也可以使用选择器。边框和圆角矩形。自定义相同。

可绘制文件夹中的 bkg.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" 
        android:drawable="@drawable/pressed" />
    <item  android:state_focused="false" 
        android:drawable="@drawable/normal" />
</selector>

可绘制文件夹中的 normal.xml

<?xml version="1.0" encoding="UTF-8"?> 
  <shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle"> 
  <solid android:color="#0AECBF"/>    
  <stroke android:width="3dp"
        android:color="#0FECFF" /> 
  <padding android:left="5dp"
         android:top="5dp"
         android:right="5dp"
         android:bottom="5dp"/> 
  <corners android:bottomRightRadius="7dp"
         android:bottomLeftRadius="7dp" 
         android:topLeftRadius="7dp"
         android:topRightRadius="7dp"/> 
  </shape>  

可绘制文件夹中的pressed.xml

<?xml version="1.0" encoding="UTF-8"?> 
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
   <solid android:color="#ff33ffff" />
 <padding android:left="5dp"
             android:top="5dp"
             android:right="5dp"
             android:bottom="5dp"/> 
    <corners android:bottomRightRadius="7dp"
             android:bottomLeftRadius="7dp" 
             android:topLeftRadius="7dp"
             android:topRightRadius="7dp"/> 
</shape>

现在设置背景

     android:background="@drawable/bkg"
于 2013-07-30T11:06:05.397 回答
0

您可以尝试设置 onTouchListener。像这样的东西

myButton.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
    if(event.getAction() == MotionEvent.ACTION_DOWN){

        // Change your color here
        return true;
    }
    return false;
  }
});

onTouchListener 应该在 onClickListener 之前触发

于 2013-07-30T11:09:28.743 回答
0

只需将选择器设置为背景可绘制。在可绘制文件夹中创建一个带有“选择器”的新 Android xml 文件:

    <selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true">
    <color android:color="@android:color/black" />
</item>
<item>
    <color android:color="@android:color/white" />
</item>
   </selector>

然后,在您的 xml 布局中,将其设置为您的 textView:

    android:background="@drawable/your_selector"

这只是一个糟糕的例子,您可以为不同的背景等创建 shape.xml。

于 2013-07-30T11:06:39.067 回答
0
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:state_selected="true" android:drawable="#002233"/>
    <item android:state_pressed="true" android:drawable="#112233"/>
    <item android:drawable="#001122"></item>
</selector>

在布局文件夹中创建一个 xml 文件(比如 text_bkgrnd),在其中添加上述代码。

现在在 main.xml 中将 textView 的背景属性设置为此创建的 xml 文件

希望这可以帮助。根据需要更改状态的哈希值

于 2013-07-30T11:06:39.757 回答
0
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" >
        <shape>
            <solid
                android:color="#61ab69" />
            <stroke
                android:width="1dp"
                android:color="#53933f" />
            <corners
                android:radius="3dp" />
            <padding
                android:left="5dp"
                android:top="5dp"
                android:right="5dp"
                android:bottom="5dp" />
        </shape>
    </item>
    <item>
        <shape>
            <gradient
                android:startColor="#009933"
                android:endColor="#00bf33"
                android:angle="270" />
            <stroke
                android:width="1dp"
                android:color="#53933f" />
            <corners
                android:radius="3dp" />
            <padding
                android:left="5dp"
                android:top="5dp"
                android:right="5dp"
                android:bottom="5dp" />
        </shape>
    </item>
</selector>

将其保存为可绘制文件夹中的 btnclick.xml 并将其用作

android:background="@drawable/btnclick

在那个文本视图中

它会正常工作

于 2013-07-30T11:07:29.330 回答
0

按钮的属性

android:background="@drawable/focus_color.xml"

//focus_color.xml

<?xml version="1.0" encoding="utf-8"?>
<selector 
    xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <item 
        android:state_pressed="true"
        android:drawable="@drawable/gradient_focus" 
        /> <!--pressed  -->
    <item 
        android:state_focused="true"
        android:drawable="@drawable/gradient_titlebar" 
        /> <!-- focused -->    
    <item 
        android:drawable="@drawable/gradient_paint" 
        /> <!-- default -->
</selector>  

//gradient_focus.xml

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >

    <gradient
        android:angle="90"
        android:endColor="#FFFFFF"
        android:startColor="#e8ebef"
        android:type="linear" />

    <stroke
        android:width="0.3dp"
        android:color="#000000" />

    <corners android:radius="0.5dp" />

</shape>  

//gradient_titlebar.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
    android:shape="rectangle">
    <gradient
        android:startColor="#E2EEFC"
        android:endColor="#BFCBD9"
        android:type="linear"
        android:angle="90"/>
    <corners android:radius="2dp" />
</shape>  

//gradient_paint.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
    android:shape="rectangle">
    <gradient
        android:startColor="#94D7F2"
        android:endColor="#65A2DB"
        android:type="linear"
        android:angle="90"/>
    <padding android:left="7dp"
        android:top="7dp"
        android:right="7dp"
        android:bottom="7dp"/>
    <corners android:radius="2dp"/>
</shape>
于 2013-07-30T11:18:56.270 回答