| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 游戏开发 -> ValueAnimator的一些骚玩法 -> 正文阅读 |
|
|
[游戏开发]ValueAnimator的一些骚玩法 |
|
使用ValueAnimator可以做一些很骚的操作,比如实现一个进度条。实现的原理很简单,利用ValueAnimator的onAnimationUpdate,均匀的从0-1变化,我们在回调中动态设置View的宽度,实现轻量的进度条。我的需求是一个循环的进度条,代码如下: private void startAnimator(View view) {
// 创建一个属性动画
mValueAnimator = ValueAnimator.ofFloat(0, 1.0f);
WindowManager wm = (WindowManager) mContext
.getSystemService(Context.WINDOW_SERVICE);
int width = wm.getDefaultDisplay().getWidth();
mValueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
Float progress = (Float) animation.getAnimatedValue();
ViewGroup.LayoutParams params = view.getLayoutParams();
params.width = (int) (progress * width);
view.setLayoutParams(params);
view.setVisibility(View.VISIBLE);
}
});
// 持续时长
mValueAnimator.setDuration(6000);
mValueAnimator.setInterpolator(new LinearInterpolator());
mValueAnimator.setRepeatCount(ValueAnimator.INFINITE);
// 播放
mValueAnimator.start();
}
|
|
|
|
|
| 上一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年11日历 | -2025/11/23 6:16:10- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |