我想创建一个像这张图片的自定义按钮:
“图片”是我的照片。
答案 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();
}
}
视觉效果如下: