如何在附图中创建自定义按钮?

时间:2013-12-30 18:02:55

标签: android button view

我想创建一个像这张图片的自定义按钮:

enter image description here

“图片”是我的照片。

2 个答案:

答案 0 :(得分:0)

一般来说,我会试试ImageButton课程。

答案 1 :(得分:0)

Android中的所有界面对象都是View类的子对象,因此只需向其中添加OnClickListener,任何对象都可以充当按钮。因此,您可以在XML中创建一个看起来完全符合您需求的ViewGroup,然后添加onClickListener。

一个简单的例子:

布局XML:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/bgimg"
    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=".MainActivity" >

    <RelativeLayout
        android:id="@+id/clickableButtonWithBorder"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:background="@drawable/border"
        android:padding="20dp" >

        <ImageView
            android:id="@+id/centerPicture"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_centerVertical="true"
            android:src="@drawable/blue_rect_icon" />
    </RelativeLayout>
</RelativeLayout>

和drawable / border.xml:

<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" >
   <solid android:color="#7fffffff" />
   <stroke android:width="1dip" android:color="#4fa5d5"/>
</shape>

Java代码:

public class MainActivity extends Activity implements OnClickListener {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        ViewGroup clickableButtonWithBorder = (ViewGroup) findViewById(R.id.clickableButtonWithBorder);
        // set transparency of the background to 50% (127/255)
        clickableButtonWithBorder.getBackground().setAlpha(127);
        clickableButtonWithBorder.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {
        Toast.makeText(getApplicationContext(), "Someone clicked!", Toast.LENGTH_SHORT).show();
    }

}

视觉效果如下:

button with transparent background