先上效果图:
在这里注意,子控件的android:layout_centerInParent="true"属性使用时要注意,如果具体的子布局使用了这个属性,那么布局就会看着不协调。
public class CustomTusi extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.test);
}
public void click(View view1){
Toast toast = new Toast(this);
View view = LayoutInflater.from(this).inflate(R.layout.toast_layout, null);
toast.setView(view);
toast.setGravity(Gravity.CENTER, 0, 0);
toast.setDuration(2000);
toast.show();
}
}
test.xml;
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<Button
android:id="@+id/btn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="click"
android:text="自定义吐司"
/>
</LinearLayout>
toast_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/shape_rec_little" >
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
>
<TextView
android:id="@+id/tv_toast"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="5dp"
android:layout_centerHorizontal="true"
android:text="温馨提示"
android:textSize="18sp" />
<TextView
android:id="@+id/tv_toast_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/tv_toast"
android:layout_centerHorizontal="true"
android:padding="5dp"
android:text="自定义吐司成功" />
</RelativeLayout>
</RelativeLayout>
shape_rec_little.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<solid android:color="#fff" />
<!-- android:radius 弧形的半径 -->
<corners android:radius="8dp" />
<!-- padding:Button里面的文字与Button边界的间隔 -->
<padding
android:left="10dp"
android:right="10dp"
android:bottom="5dp"
android:top="5dp"
/>
<stroke
android:width="2px"
android:color="#ccc" />
</shape>