自定义Toast样式+改变Toast宽高
2016-11-13 本文已影响0人
Alden_Lei
最近在一个项目的开发中有一个需要自定义Toast样式的需求,起初想想应该不复杂,不过在写代码的时候就发现不能改变Toast的宽高大小,没办法,只有一步一步的看源码解决。如果你查看源码会发现Toast的大小是由内容所占大小决定的,因此我们要解决的就是固定内容的大小。废话不多说,上代码。
1.首先画一个自定义Toast样式的布局toast_clear_layout.xml,如下:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/toast_relative"
android:background="@drawable/toast_shape"
android:layout_width="130dp"
android:layout_height="130dp">
<LinearLayout
android:id="@+id/toast_linear"
android:padding="10dp"
android:orientation="vertical"
android:layout_width="130dp"
android:layout_height="130dp">
<ImageView
android:layout_marginTop="20dp"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_marginBottom="10dp"
android:src="@mipmap/toast_ok" />
<TextView
android:layout_marginTop="-10dp"
android:id="@+id/tv_toast_clear"
android:gravity="center"
android:layout_width="match_parent"
android:layout_height="30dp"
android:textSize="13sp"
android:textColor="#fff"
android:text="已清空小纸条记录" />
</LinearLayout>
</RelativeLayout>
-效果如下
效果图.png2.Java代码
(大家注意:这里有个坑,在布局文件中设置的宽高度不会起作用,必须在代码中动态设置,而且还不能设置布局文件的根节点的宽高度,一样无效,因此我设置LinearLayout的宽高度)
//自定义Toast控件
View toastView =LayoutInflater.from(SmallPaperActivity.this).inflate(R.layout.toast_clear_layout, null);
LinearLayout relativeLayout = (LinearLayout)toastView.findViewById(R.id.toast_linear);
//动态设置toast控件的宽高度,宽高分别是130dp
//这里用了一个将dp转换为px的工具类PxUtil
RelativeLayout.LayoutParams layoutParams = newRelativeLayout.LayoutParams((int) PxUtil.dpToPx(SmallPaperActivity.this, 130), (int)PxUtil.dpToPx(SmallPaperActivity.this, 130));
relativeLayout.setLayoutParams(layoutParams);
TextView textView = (TextView)toastView.findViewById(R.id.tv_toast_clear);
textView.setText("已清空小纸条记录");
Toast toast = new Toast(SmallPaperActivity.this);
toast.setDuration(Toast.LENGTH_SHORT);
toast.setGravity(Gravity.CENTER, 0, 0);
toast.setView(toastView);
toast.show();
PxUtil工具类:dp与px单位相互转换的工具类
import android.content.Context;
/**
* Created by L_Alden on 2016/11/10.
* px与dp相互转换工具类
*/
public class PxUtil {
public static float dpToPx(Context context, int dp) {
//获取屏蔽的像素密度系数
float density = context.getResources().getDisplayMetrics().density;
return dp * density;
}
public static float pxTodp(Context context, int px) {
//获取屏蔽的像素密度系数
float density = context.getResources().getDisplayMetrics().density;
return px / density;
}
}