定制自己的动画 View 控件(Canvas 使用)
定制自己的动画 View 控件(Canvas 使用)
如果要定义自己的 View 控件,则需要新建一个类继承 android.view.View。然后在 onDraw 中写自己需要实现的方式。
这里定制了一个非常简单的动画,让 Android Studio 默认工程的圆形 logo 沿着对角线运动,且运动过程中进行旋转。
以下为具体步骤:
新建工程,从 mipmap 下复制一个 ic_launcher_round.png 到 drawable 目录下
新建一个类,继承自 View,这里命名为 MyView,需要注意,它的构造函数需要选择 2 个形参的
private Resources mResources;
private Paint mPaint;
private Bitmap mBitmap;
private int mBitmapHeight;
private int mBitmapWidth;
private int mViewHeight;
private int mViewWidth;
private int x;
private int y;
private int rotation;
public MyView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
mResources = getResources();
initPaint();
initBitmap();
x = mViewWidth;
y = mViewHeight;
rotation = 0;
}
private void initPaint() {
mPaint = new Paint();
mPaint.setAntiAlias(true);
mPaint.setDither(true);
mPaint.setFilterBitmap(true);
}
private void initBitmap() {
mBitmap = ((BitmapDrawable)mResources
.getDrawable(R.drawable.ic_launcher_round,null))
.getBitmap();
mBitmapHeight = mBitmap.getHeight();
mBitmapWidth = mBitmap.getWidth();
}
- 重写 onDraw 方法
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
// canvas.drawBitmap(mBitmap,0,0,mPaint);
/**
* 不旋转画布的方式
* 位置 A 和 位置 B 不重叠,位置 B 和位置 C 重叠
* 说明位置 A 的图形恢复完成后,已经主动将画布恢复现场,则save()和restore()方法本身并没有什么用
*/
// canvas.save();
// Matrix matrix = new Matrix();
// matrix.postTranslate(x,y);
// matrix.postRotate(rotation,x + mBitmapWidth / 2,y + mBitmapHeight / 2);
// 这里按照网络上的说法,画布已经经过了移动和旋转
// 位置 A
// canvas.drawBitmap(mBitmap,matrix,mPaint);
// 位置 B
// canvas.drawBitmap(mBitmap,0,0,mPaint);
// canvas.restore();
// 位置 C
// canvas.drawBitmap(mBitmap,0,0,mPaint);
/**
* 旋转画布的方式
*/
canvas.save();
// 画布的原点移动到了(x,y)点 --> (x,y)->(0,0)
canvas.translate(x,y);
// 画布在(0,0)点进行了旋转,旋转角度是 rotation,旋转的中心点是(mBitmapWidth/2,mBitmapHeight/2)
canvas.rotate(rotation,mBitmapWidth / 2,mBitmapHeight / 2);
// 在(0,0)点绘制需要的图形
canvas.drawBitmap(mBitmap,0,0,mPaint);
// 将画布恢复
canvas.restore();
// 还是用之前的语句再绘制需要的图形
canvas.drawBitmap(mBitmap,0,0,mPaint); // 图形不重叠
x++;
y++;
rotation+=1;
if (x > mViewWidth - mBitmapWidth || y > mViewHeight - mBitmapHeight) {
x = 0;
y = 0;
}
postInvalidate(); // 这句话将会调用 onDraw(),也就是说,这个函数陷入死循环
}
定制自己的动画 View 控件(Canvas 使用)的更多相关文章
- Android 自定义View修炼-打造完美的自定义侧滑菜单/侧滑View控件
一.概述 在App中,经常会出现侧滑菜单,侧滑滑出View等效果,虽然说Android有很多第三方开源库,但是实际上 咱们可以自己也写一个自定义的侧滑View控件,其实不难,主要涉及到以下几个要点: ...
- Android 打造完美的侧滑菜单/侧滑View控件
概述 Android 打造完美的侧滑菜单/侧滑View控件,完全自定义实现,支持左右两个方向弹出,代码高度简洁流畅,兼容性高,控件实用方便. 详细 代码下载:http://www.demodashi. ...
- 旋转动画用控件RotateView
旋转动画用控件RotateView 最终效果: 源码: RotateView.h 与 RotateView.m // // RotateView.h // RotateAnimationView // ...
- iOS开发UI篇—使用picker View控件完成一个简单的选餐应用
iOS开发UI篇—使用picker View控件完成一个简单的选餐应用 一.实现效果 说明:点击随机按钮,能够自动选取,下方数据自动刷新. 二.实现思路 1.picker view的有默认高度为162 ...
- Scroll View 控件以Thumbnail的方式显示一个目录的全部图片,相似图片浏览器
MAC : XCode -> Scroll View 控件以Thumbnail的方式显示一个目录的全部图片,类似图片浏览器 STEP1:将两个目录复制到project里面ImageBrowser ...
- 重新想象 Windows 8 Store Apps (7) - 控件之布局控件: Canvas, Grid, StackPanel, VirtualizingStackPanel, WrapGrid, VariableSizedWrapGrid
原文:重新想象 Windows 8 Store Apps (7) - 控件之布局控件: Canvas, Grid, StackPanel, VirtualizingStackPanel, WrapGr ...
- 巧用Handler获取View控件信息
众所周知,在Android实际开发中,对于某些复杂多变的情况,控件的位置摆放.大小控制并非是xml类型的layout文件完全可以搞定的.此时,我们通常会使用Java代码来通过动态计算,将指定的控件摆放 ...
- Android开发技巧——定制仿微信图片裁剪控件
拍照--裁剪,或者是选择图片--裁剪,是我们设置头像或上传图片时经常需要的一组操作.上篇讲了Camera的使用,这篇讲一下我对图片裁剪的实现. 背景 下面的需求都来自产品. 裁剪图片要像微信那样,拖动 ...
- Android自定义view控件
转载自: http://blog.163.com/ppy2790@126/blog/static/103242241201382210910473/ 开发自定义控件的步骤: 1.了解View的工作原理 ...
随机推荐
- 【PTA 天梯赛】L3-003 社交集群(并查集)
当你在社交网络平台注册时,一般总是被要求填写你的个人兴趣爱好,以便找到具有相同兴趣爱好的潜在的朋友.一个“社交集群”是指部分兴趣爱好相同的人的集合.你需要找出所有的社交集群. 输入格式: 输入在第一行 ...
- Kali之——解决物理机U盘安装Kali Linux2018.1,光驱无法加载问题
Kali系统和烧录软件 链接:https://pan.baidu.com/s/1v78d62hdF95NM2minct9sw 提取码:b08k 1.无效的方法: (1)执行 df -m,然后查看U盘设 ...
- encodeURIComponent编码反斜杠 \ (正则匹配)
记录一个小bug... 前言废话: 1. 功能需求:修改输入框的内容,获取字符串传给后端保存. 2. bug历程:刚开始直接获取value值传过去.后来测试发现%&这些特殊字符无法传递后,在前 ...
- Delphi Android USB声明文件
自己转的比较全面的USB声明文件: unit Androidapi.JNI.USB; interface uses AndroidAPI.JNIBridge, Androidapi.JNI.JavaT ...
- Maven plugin插件---appassembler-maven-plugin快速配置
使用appassembler-maven-plugin 打包自定义目录 1.Pom中添加 <plugin> <artifactId>maven-resources-plugin ...
- Ubuntu16.04安装CDH5.14.2
一.安装cloudera manager(下文简称cm) (一).环境及软件准备: 1.环境:Ubuntu16.04 desktop x 3 台 ip分别为:10.132.226.121,10.132 ...
- Python学习 :异常处理
异常处理 什么是异常处理 - python解释器检测到错误,触发异常(也允许程序员自己触发了异常) - 程序员编写特定的代码,专门用来捕捉这个异常(这段代码与程序逻辑无关,只与异常处理有关) - 如果 ...
- leetcode记录-两数之和
给定一个整数数组和一个目标值,找出数组中和为目标值的两个数. 你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用. 示例: 给定 nums = [2, 7, 11, 15], target ...
- 笔记-scrapy-selector
笔记-scrapy-selector scrapy版本:1.5.0 1.总述 scrapy内置selector建立在lxml上. 2.使用 可以使用xpath和css方法来进行解析,两者都返回列表: ...
- 20155217 2016-2017-2 《Java程序设计》第3周学习总结
20155217 2016-2017-2 <Java程序设计>第3周学习总结 教材学习内容总结 第四章 要产生对象必须先定义类,类定义时使用class关键词,建立实例要使用new关键词. ...