返回顶部
首页 > 资讯 > 移动开发 >Android自定义View实现QQ音乐中圆形旋转碟子
  • 547
分享到

Android自定义View实现QQ音乐中圆形旋转碟子

qq音乐viewAndroid 2022-06-06 07:06:45 547人浏览 薄情痞子
摘要

QQ音乐中圆形旋转碟子 思路分析: 1、在onMeasure中测量整个View的宽和高后,设置宽高 2、获取我们res的图片资源后,在ondraw方法中进行绘制圆形图片 3、通

QQ音乐中圆形旋转碟子

思路分析:
1、在onMeasure中测量整个View的宽和高后,设置宽高
2、获取我们res的图片资源后,在ondraw方法中进行绘制圆形图片
3、通过Handler发送Runnable来启动旋转线程(如果只想做圆形头像的话,这步可以去掉)
4、在布局中使用我们的View

效果图:


贴出我们的变量信息:


//view的宽和高 
int mHeight = 0; 
int mWidth = 0; 
//圆形图片 
Bitmap bitmap = null; 
//圆形图片的真实半径 
int radius = 0; 
//旋转动画的矩形 
Matrix matrix = new Matrix(); 
//旋转动画的角度 
int degrees = 0; 

步骤一:测量整个View的宽和高后,设置宽高


@Override 
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
 super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
 //测量整个View的宽和高 
 mWidth = measuredWidth(widthMeasureSpec); 
 mHeight= measuredHeight(heightMeasureSpec); 
 setMeasuredDimension(mWidth, mHeight); 
} 
private int measuredWidth(int widthMeasureSpec) { 
 int Mode = MeasureSpec.getMode(widthMeasureSpec); 
 int Size = MeasureSpec.getSize(widthMeasureSpec); 
 if (Mode == MeasureSpec.EXACTLY) { 
  mWidth = Size; 
 } else { 
  //由图片决定宽度 
  int value = getPaddingLeft() + getPaddingRight() + bitmap.getWidth(); 
  if (Mode == MeasureSpec.AT_MOST) { 
   //由图片和Padding决定宽度,但是不能超过View的宽 
   mWidth = Math.min(value, Size); 
  } 
 } 
 return mWidth; 
} 
private int measuredHeight(int heightMeasureSpec) { 
 int Mode = MeasureSpec.getMode(heightMeasureSpec); 
 int Size = MeasureSpec.getSize(heightMeasureSpec); 
 if (Mode == MeasureSpec.EXACTLY) { 
  mHeight = Size; 
 } else { 
  //由图片决定高度 
  int value = getPaddingTop() + getPaddingBottom() + bitmap.getHeight(); 
  if (Mode == MeasureSpec.AT_MOST) { 
   //由图片和Padding决定高度,但是不能超过View的高 
   mHeight = Math.min(value, Size); 
  } 
 } 
 return mHeight; 
} 

步骤二:获取我们res的图片资源后,在ondraw方法中进行绘制圆形图片


//获取res的图片资源 
bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.icon); 
@Override 
protected void onDraw(canvas canvas) { 
 super.onDraw(canvas); 
 canvas.concat(matrix); 
 //真实的半径必须是View的宽高最小值 
 radius = Math.min(mWidth, mHeight); 
 //如果图片本身宽高太大,进行相应的缩放 
 bitmap = Bitmap.createScaledBitmap(bitmap, radius, radius, false); 
 //画圆形图片 
 canvas.drawBitmap(createCircleImage(bitmap, radius), 0, 0, null); 
 matrix.reset(); 
} 
private Bitmap createCircleImage(Bitmap source, int radius) { 
 Paint paint = new Paint(); 
 paint.setAntiAlias(true); 
 Bitmap target = Bitmap.createBitmap(radius, radius, Bitmap.Config.ARGB_8888); 
 //产生一个同样大小的画布 
 Canvas canvas = new Canvas(target); 
 //首先绘制圆形 
 canvas.drawCircle(radius / 2, radius / 2, radius / 2, paint); 
 //使用SRC_IN模式显示后画图的交集处 
 paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN)); 
 //绘制图片,从(0,0)画 
 canvas.drawBitmap(source, 0, 0, paint); 
 return target; 
} 

步骤三:通过Handler发送Runnable来启动旋转线程


//开始旋转 
mHandler.post(runnable); 
[java] view plain copy 在CODE上查看代码片派生到我的代码片
//-----------旋转动画----------- 
Handler mHandler = new Handler(); 
Runnable runnable = new Runnable() { 
 @Override 
 public void run() { 
  matrix.postRotate(degrees++, radius / 2, radius / 2); 
  //重绘 
  invalidate(); 
  mHandler.postDelayed(runnable, 50); 
 } 
}; 

步骤四:在布局中使用我们的View


<com.handsome.cycle.MyCycleView 
 Android:layout_width="wrap_content" 
 android:layout_height="wrap_content" /> 

下面是整个类的源码


public class MyCycleView extends View { 
 //view的宽和高 
 int mHeight = 0; 
 int mWidth = 0; 
 //圆形图片 
 Bitmap bitmap = null; 
 //圆形图片的真实半径 
 int radius = 0; 
 //旋转动画的矩形 
 Matrix matrix = new Matrix(); 
 //旋转动画的角度 
 int degrees = 0; 
 //-----------旋转动画----------- 
 Handler mHandler = new Handler(); 
 Runnable runnable = new Runnable() { 
  @Override 
  public void run() { 
   matrix.postRotate(degrees++, radius / 2, radius / 2); 
   //重绘 
   invalidate(); 
   mHandler.postDelayed(runnable, 50); 
  } 
 }; 
 public MyCycleView(Context context) { 
  super(context); 
  initView(); 
 } 
 public MyCycleView(Context context, AttributeSet attrs) { 
  super(context, attrs); 
  initView(); 
 } 
 public MyCycleView(Context context, AttributeSet attrs, int defStyleAttr) { 
  super(context, attrs, defStyleAttr); 
  initView(); 
 } 
 public void initView() { 
  //获取res的图片资源 
  bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.icon); 
  //开始旋转 
  mHandler.post(runnable); 
 } 
 @Override 
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
  super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
  //测量整个View的宽和高 
  mWidth = measuredWidth(widthMeasureSpec); 
  mHeight = measuredHeight(heightMeasureSpec); 
  setMeasuredDimension(mWidth, mHeight); 
 } 
 private int measuredWidth(int widthMeasureSpec) { 
  int Mode = MeasureSpec.getMode(widthMeasureSpec); 
  int Size = MeasureSpec.getSize(widthMeasureSpec); 
  if (Mode == MeasureSpec.EXACTLY) { 
   mWidth = Size; 
  } else { 
   //由图片决定宽度 
   int value = getPaddingLeft() + getPaddingRight() + bitmap.getWidth(); 
   if (Mode == MeasureSpec.AT_MOST) { 
    //由图片和Padding决定宽度,但是不能超过View的宽 
    mWidth = Math.min(value, Size); 
   } 
  } 
  return mWidth; 
 } 
 private int measuredHeight(int heightMeasureSpec) { 
  int Mode = MeasureSpec.getMode(heightMeasureSpec); 
  int Size = MeasureSpec.getSize(heightMeasureSpec); 
  if (Mode == MeasureSpec.EXACTLY) { 
   mHeight = Size; 
  } else { 
   //由图片决定高度 
   int value = getPaddingTop() + getPaddingBottom() + bitmap.getHeight(); 
   if (Mode == MeasureSpec.AT_MOST) { 
    //由图片和Padding决定高度,但是不能超过View的高 
    mHeight = Math.min(value, Size); 
   } 
  } 
  return mHeight; 
 } 
 @Override 
 protected void onDraw(Canvas canvas) { 
  super.onDraw(canvas); 
  canvas.concat(matrix); 
  //真实的半径必须是View的宽高最小值 
  radius = Math.min(mWidth, mHeight); 
  //如果图片本身宽高太大,进行相应的缩放 
  bitmap = Bitmap.createScaledBitmap(bitmap, radius, radius, false); 
  //画圆形图片 
  canvas.drawBitmap(createCircleImage(bitmap, radius), 0, 0, null); 
  matrix.reset(); 
 } 
 private Bitmap createCircleImage(Bitmap source, int radius) { 
  Paint paint = new Paint(); 
  paint.setAntiAlias(true); 
  Bitmap target = Bitmap.createBitmap(radius, radius, Bitmap.Config.ARGB_8888); 
  //产生一个同样大小的画布 
  Canvas canvas = new Canvas(target); 
  //首先绘制圆形 
  canvas.drawCircle(radius / 2, radius / 2, radius / 2, paint); 
  //使用SRC_IN模式显示后画图的交集处 
  paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN)); 
  //绘制图片,从(0,0)画 
  canvas.drawBitmap(source, 0, 0, paint); 
  return target; 
 } 
} 
您可能感兴趣的文章:Android自定义View实现QQ运动积分转盘抽奖功能Android 自定View实现仿QQ运动步数圆弧及动画效果Android自定义View仿微博运动积分动画效果Android UI之ImageView实现图片旋转和缩放Android使用RotateImageView 旋转ImageViewAndroid UI设计系列之ImageView实现ProgressBar旋转效果(1)Android自定义View叶子旋转完整版(六)Android自定义View实现叶子飘动旋转效果(四)Android中imageView图片放大缩小及旋转功能示例代码Android自定义View图片按Path运动和旋转


--结束END--

本文标题: Android自定义View实现QQ音乐中圆形旋转碟子

本文链接: https://lsjlt.com/news/23751.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android自定义View实现QQ音乐中圆形旋转碟子
    QQ音乐中圆形旋转碟子 思路分析: 1、在onMeasure中测量整个View的宽和高后,设置宽高 2、获取我们res的图片资源后,在ondraw方法中进行绘制圆形图片 3、通...
    99+
    2022-06-06
    qq音乐 view Android
  • Android自定义view实现圆形与半圆形菜单
    前不久看到鸿洋大大的圆形菜单,就想开始模仿,因为实在是太酷了,然后自己根据别人(zw哥)给我讲的一些思路、一些分析,就开始改造自己的圆形菜单了。 文章结构:1.功能介绍以及展示...
    99+
    2022-06-06
    菜单 view Android
  • Android自定义View实现圆形进度条
    本文实例为大家分享了Android自定义View实现圆形进度条的具体代码,供大家参考,具体内容如下 原理非常简单,在自定义View的基础上使用Canvas的drawCircle画两个...
    99+
    2024-04-02
  • Android自定义View实现多片叶子旋转滑动(五)
    上一篇《Android 自定义View(四) 叶子飘动+旋转效果》实现了单片叶子的滑动及旋转,下面实现多片叶子的滑动旋转功能 实现思路比较简单,就是添加一个叶子Leaf类,储...
    99+
    2022-06-06
    view Android
  • Android自定义View实现叶子飘动旋转效果(四)
    上一篇实现了叶子飘动功能,《Android自定义叶子飘动》 现在实现旋转效果 要实现这个效果,要在之前的功能上添加2个功能 1、通过matrix.postTranslate(...
    99+
    2022-06-06
    view Android
  • Android自定义View叶子旋转完整版(六)
    上一篇实现多叶子飘动旋转,今天完成最后的功能。 1、添加右侧旋转枫叶 2、添加滑动条效果,显示百分比 3、修复叶子飘出边框问题 1、添加右侧旋转叶子 Bitmap turn...
    99+
    2022-06-06
    view Android
  • Android自定义view实现圆形进度条效果
    Android中实现进度条有很多种方式,自定义进度条一般是继承progressBar或继承view来实现,本篇中讲解的是第二种方式。 先上效果图: 实现圆形进度条总体来说并不难,还...
    99+
    2024-04-02
  • Android怎么自定义View实现圆形进度条
    本文小编为大家详细介绍“Android怎么自定义View实现圆形进度条”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android怎么自定义View实现圆形进度条”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。原...
    99+
    2023-07-02
  • Android自定义View实现圆形加载进度条
    本文实例为大家分享了Android自定义View实现圆形加载进度条的具体代码,供大家参考,具体内容如下 效果图 话不多说,咱们直接看代码 首先第一种: 1、创建自定义View类 p...
    99+
    2024-04-02
  • Android自定义view实现圆形、圆角和椭圆图片(BitmapShader图形渲染)
    一、前言 Android实现圆角矩形,圆形或者椭圆等图形,一般主要是个自定义View加上使用Xfermode实现的。实现圆角图片的方法其实不少,常见的就是利用Xfermode,...
    99+
    2022-06-06
    view 图片 椭圆 Android
  • Android自定义View实现简单的圆形Progress效果
    先给大家展示下效果图,如果感觉不错,请参考实现思路: 我们要实现一个自定义的再一个圆形中绘制一个弧形的自定义View,思路是这样的:   先要创建一个类ProgressVie...
    99+
    2022-06-06
    view progress Android
  • Android自定义Drawable实现圆形和圆角
    本文实例为大家分享了自定义Drawable实现圆形和圆角的具体代码,供大家参考,具体内容如下圆形package com.customview.widget;import android.graphics.Bitmap;import andr...
    99+
    2023-05-30
    android drawable 圆形
  • android自定义view实现圆周运动
    本文实例为大家分享了android自定义view实现圆周运动的具体代码,供大家参考,具体内容如下 思想 自定义Animation,自己定义半径,相当于原来控件的位置为(0,0),按...
    99+
    2024-04-02
  • 详解Android如何自定义view实现圆形进度条
    Android中实现进度条有很多种方式,自定义进度条一般是继承progressBar或继承view来实现,本篇中讲解的是第二种方式。 先上效果图: 实现圆形进度条总体来说并不难,还...
    99+
    2024-04-02
  • Android中怎么通过自定义View实现圆形切图效果
    本篇文章给大家分享的是有关Android中怎么通过自定义View实现圆形切图效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。实现思路使用一个Paint,将得到的Bitmap设...
    99+
    2023-05-30
  • Android自定义view实现半圆环效果
    本文实例为大家分享了Android自定义view实现半圆环的具体代码,供大家参考,具体内容如下 1.自定义属性 <declare-styleable name="Semicir...
    99+
    2024-04-02
  • Android实现自定义圆形进度条
    今天无意中发现一个圆形进度,想想自己实现一个,如下图: 基本思路是这样的: 1.首先绘制一个实心圆 2.绘制一个白色实心的正方形,遮住实心圆 3.在圆的中心动态绘制当前进度的...
    99+
    2022-06-06
    自定义 进度条 Android
  • Android自定义View实现心形图案
    本文实例为大家分享了Android自定义View实现心形的具体代码,供大家参考,具体内容如下 通过继承View实现的❤形 在绘制心形需要Path类中的两个重要方法分别...
    99+
    2024-04-02
  • Android中怎么通过自定义View实现画圆
    Android中怎么通过自定义View实现画圆,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。引入布局<xml version="1.0...
    99+
    2023-05-30
    android
  • Android如何实现自定义View圆形和拖动圆跟随手指拖动
    这篇文章主要介绍Android如何实现自定义View圆形和拖动圆跟随手指拖动,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!单纯的自定义一个圆非常简单 只需要几步就完成 拖动圆添加实现触摸事件即可 我在第一次自定义Vi...
    99+
    2023-05-30
    android view
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作