单击时将复选标记图像添加到ImageButton

时间:2016-05-04 21:04:33

标签: java android xml

这是我的项目:

enter image description here

当我触摸每行中的一张图片时,我想要这样的东西:

enter image description here

这就是我在XML中的含义:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="android.goparty.rayoruiz.gopartyandroid.MainActivity">
<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:text="@string/choises_title"
    android:id="@+id/choises_title"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true" />

<ScrollView
    android:layout_width="500px"
    android:layout_height="600px"
    android:id="@+id/scrollView"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true"
    android:layout_alignParentRight="true"
    android:layout_alignParentEnd="true"
    android:layout_alignParentBottom="true"
    android:layout_below="@+id/choises_title">


    <TableLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <TableRow
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:minHeight="109dp"
            android:weightSum="1"
            android:background="@mipmap/bottomlist"
            android:paddingTop="10dp"
            android:nestedScrollingEnabled="false"
            android:paddingBottom="10dp"
            android:layout_marginTop="10px">


            <ImageButton
                android:layout_width="0dip"
                android:layout_height="109dp"
                android:id="@+id/houseParty"
                android:layout_weight="0.40"
                android:background="@mipmap/houseicon"
                android:layout_gravity="left"
                android:layout_marginRight="@android:dimen/app_icon_size"
                android:layout_marginLeft="@android:dimen/app_icon_size" />

            <ImageButton
                android:layout_width="0dip"
                android:layout_height="109dp"
                android:layout_weight="0.40"
                android:id="@+id/clubParty"
                android:layout_gravity="right"
                android:background="@mipmap/nightclubsicon" />

        </TableRow>
        <TableRow
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:minHeight="109dp"
            android:weightSum="1"
            android:background="@mipmap/bottomlist"
            android:paddingTop="10dp"
            android:nestedScrollingEnabled="false"
            android:paddingBottom="10dp"
            android:layout_marginTop="10px">


            <ImageButton
                android:layout_width="0dip"
                android:layout_height="109dp"
                android:id="@+id/drink"
                android:layout_weight="0.40"
                android:background="@mipmap/drink"
                android:layout_gravity="left"
                android:layout_marginRight="@android:dimen/app_icon_size"
                android:layout_marginLeft="@android:dimen/app_icon_size" />

            <ImageButton
                android:layout_width="0dip"
                android:layout_height="109dp"
                android:layout_weight="0.40"
                android:id="@+id/nodrink"
                android:layout_gravity="right"
                android:background="@mipmap/nodrink" />

        </TableRow>
    </TableLayout>
</ScrollView>

好的,我有不透明度设置alpha属性。

public void onClick(View v){
   int[] array = new int[2];
   houseParty.getLocationOnScreen(array);
   **houseParty.setAlpha(new Float(0.50));**
 }

如何在点击时更改按钮的图片?

1 个答案:

答案 0 :(得分:0)

使用setOnClickListener检测到点击时,可以交换ImageButtons的图像。这是一个可能的实现:

ImageButton houseParty = (ImageButton) findViewById(R.id.houseParty);
houseParty.setTag(0); // We associate 0 with not pressed
houseParty.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {

        // Change image. 
        if(houseParty.getTag()==0){
            houseParty.setImageDrawable(getResources().getDrawable(
                R.drawable.house_party_checked));
            houseParty.setTag(1); // Now button is pressed

        } else {
            houseParty.setImageDrawable(getResources().getDrawable(
                R.drawable.house_party));
            houseParty.setTag(0); // Now button is not pressed
        }
    }
});