Android自定义view仿QQ的Tab按钮动画效果(示例代码)
作者:晓梦千年
这篇文章主要介绍了Android自定义view仿QQ的Tab按钮动画效果(示例代码),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下
话不多说 先上效果图
实现其实很简单,先用两张图
一张是背景的图,一张是笑脸的图片,笑脸的图片是白色,可能看不出来。实现思路:主要是再触摸view的时候同时移动这两个图片,但是移动的距离不一样,造成的错位感,代码很简单:
import android.content.Context import android.graphics.* import android.util.AttributeSet import android.view.MotionEvent import android.view.View import com.example.dawnmvvm.R import com.example.dawnmvvm.util.LogUtil class MyDrawBitmap @JvmOverloads constructor(context: Context, attrs: AttributeSet? = null, defStyleAttr: Int = 0, defStyleRes: Int = 0) : View(context, attrs, defStyleAttr, defStyleRes) { private var dx = 0f private var dy = 0f private var dx1 =0f private var dy1 = 0f private val bitmap: Bitmap by lazy { BitmapFactory.decodeResource(resources, R.drawable.bg_tab);//背景 } private val bitmap2: Bitmap by lazy { BitmapFactory.decodeResource(resources, R.drawable.img_smile);//笑脸 } override fun draw(canvas: Canvas?) { super.draw(canvas) LogUtil.e("MyDrawBitmap===x===${dx}") LogUtil.e("MyDrawBitmap===y===${dy}") if(dx<0){ dx=0f } if(dy<0){ dy=0f; } canvas?.drawBitmap(bitmap, dx, dy, null);//移动背景 canvas?.drawBitmap(bitmap2, dx1, dy1, null);//移动笑脸 } override fun onTouchEvent(event: MotionEvent): Boolean { when (event.action) { MotionEvent.ACTION_UP-> { dx = 0f dy = 0f dx1 = 0f dy1 = 0f } else->{ dx = event.x/20f dy = event.y/20f dx1 = event.x/10f dy1 = event.y/10f } } invalidate() return true; } }
是不是很简单,不过不是很完美
到此这篇关于Android自定义view仿QQ的Tab按钮动效效果(示例代码)的文章就介绍到这了,更多相关Android仿QQ的Tab按钮动效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- Android开发教程之如何屏蔽View的重复点击
- Android自定义view实现输入框效果
- Android实现的RecyclerView适配器
- Android自定义View仿大众点评星星评分控件
- Android自定义View实现雪花特效
- Android Filterable实现Recyclerview筛选功能的示例代码
- Android 滑动Scrollview标题栏渐变效果(仿京东toolbar)
- Android自定义View实现圆弧进度的效果
- Android使用ScrollView实现滚动效果
- Android自定义view之围棋动画效果的实现
- Android自定义View实现分段选择按钮的实现代码
- 详解Android WebView监听console错误信息
- Android 处理 View 重复点击的多种方法