Android Toast 吐司 自定义使用 实现动态打勾对号效果 Toast自定义教程(三)

本文介绍如何在Android中自定义Toast并展示图片,通过自定义View实现动态打勾对号效果,详细解释了布局设计及代码实现。

这篇博客主要是写了功能的实现,在前面已经写了原理。

Android 自定义View 通过Paint和Canvas实现动态打勾对号效果

Android Toast 吐司 自定义使用 展示图片 Toast自定义教程(一)

老规矩,先上效果图

效果图

其实就是复用了之前写的自定义view,然后再写一个自定义布局的Toast。

动态打勾不再讲解,需要了解点击这里

先说布局,很简单的一个布局

布局view_toast_image.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="#7A2B2929"
    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">
        <com.example.drawhookviewdemo.DrawHookMarkView
            android:layout_width="100dp"
            android:layout_height="90dp" />
        <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>

偷了个懒直接在MainActivity写了方法

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        button.setOnClickListener {showToastWithImage("登录成功")  }

    }
    //带图片的toast
    fun showToastWithImage(message: CharSequence) {
        var mtoastView = LayoutInflater.from(applicationContext).inflate(R.layout.view_toast_image, null)
        val relativeLayout = mtoastView?.findViewById(R.id.toast_linear) as LinearLayout
        //动态设置toast控件的宽高度,宽高分别是130dp
        //这里用了一个将dp转换为px的工具类PxUtil
        val layoutParams = RelativeLayout.LayoutParams(DisplayUtils.dp2px(applicationContext, 130f).toInt(), DisplayUtils.dp2px(applicationContext, 130f).toInt())
        relativeLayout.setLayoutParams(layoutParams)
        val textView = mtoastView?.findViewById(R.id.tv_toast_clear) as TextView
        textView.text = message
        val mToast = Toast(application)
        mToast.setDuration(Toast.LENGTH_LONG);
        mToast?.setGravity(Gravity.CENTER, 0, 0)
        mToast.setView(mtoastView)
        mToast?.show()
    }
}

代码地址:github

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值