欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android自定义view仿QQ的Tab按钮动画效果(示例代码)

程序员文章站 2022-09-26 10:01:32
话不多说 先上效果图实现其实很简单,先用两张图一张是背景的图,一张是笑脸的图片,笑脸的图片是白色,可能看不出来。实现思路:主要是再触摸view的时候同时移动这两个图片,但是移动的距离不一样,造成的错位...

话不多说 先上效果图

Android自定义view仿QQ的Tab按钮动画效果(示例代码)

实现其实很简单,先用两张图

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按钮动效内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!