像音乐播放App一样移动背景
来源:互联网 发布:义乌淘宝培训班 编辑:程序博客网 时间:2024/04/30 06:02
如果你经常听歌,你会发现歌曲app的背景会随着音乐移动的,从左到右或者从上到下,这种动画虽然简单,但是这里有一个技巧。如果你还不明白这种动效看看下面的demo
(更多详细请参考:https://github.com/flavienlaurent/PanningView)
一,使用setImageMatrix播放图片动画
下面是官方文档给出的解释
你可以看到这里的解释很简单,就是代替ImageView的图像矩阵,然后configureBounds和invalidate被调用。
在java代码中我们可以设置Matrix的scaleType
mImageView.setScaleType(ScaleType.MATRIX)
或者在xml文件中设置
android:scaleType="matrix"
下面是ImageView的初始矩阵(matrix)
在x和y方向上放大2倍
final Matrix matrix = new Matrix();matrix.postScale(2, 2);imageView.setImageMatrix(matrix);
final Matrix matrix = new Matrix();matrix.postScale(2, 2);matrix.postRotate(15);imageView.setImageMatrix(matrix);
二,使你的图片移动
首先我们需要计算ImageView当前方向(水平,纵向)和图片当前方向的比例,就比如水平方向吧,我们就要让图片和view的高度相同,横向放大或者缩小。
float scaleFactor = (float)imageView.getHeight() / (float) drawable.getIntrinsicHeight();mMatrix.postScale(scaleFactor, scaleFactor);
这样我们就能保证图片的高和ImageView相同,并且填充满ImageView.
接下来我们就让ImageView的图片移动,我们要用到一个强大的Android动画框架:ValueAnimator,其原理就是利用ImageView的图像矩阵在x轴方向变换移动。
mAnimator = ValueAnimator.ofFloat(0, 100);mAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { float value = (Float) animation.getAnimatedValue(); matrix.reset(); matrix.postScale(scaleFactor, scaleFactor); matrix.postTranslate(-value, 0); imageView.setImageMatrix(matrix); }});mAnimator.setDuration(5000);mAnimator.start();
整个代码如下:
package com.testimageview;import android.animation.Animator;import android.animation.AnimatorListenerAdapter;import android.animation.ValueAnimator;import android.app.Activity;import android.graphics.Matrix;import android.graphics.RectF;import android.os.Bundle;import android.widget.ImageView;public class MainActivity extends Activity{ private static final int RightToLeft = 1; private static final int LeftToRight = 2; private static final int DURATION = 5000; private ValueAnimator mCurrentAnimator; private final Matrix mMatrix = new Matrix(); private ImageView mImageView; private float mScaleFactor; private int mDirection = RightToLeft; private RectF mDisplayRect = new RectF(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mImageView = (ImageView) findViewById(R.id.imageView); mImageView.post(new Runnable() { @Override public void run() { mScaleFactor = (float) mImageView.getHeight() / (float) mImageView.getDrawable().getIntrinsicHeight(); mMatrix.postScale(mScaleFactor, mScaleFactor); mImageView.setImageMatrix(mMatrix); animate(); } }); } private void animate() { updateDisplayRect(); if(mDirection == RightToLeft) { animate(mDisplayRect.left, mDisplayRect.left - (mDisplayRect.right - mImageView.getWidth())); } else { animate(mDisplayRect.left, 0.0f); } } private void animate(float from, float to) { mCurrentAnimator = ValueAnimator.ofFloat(from, to); mCurrentAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { float value = (Float) animation.getAnimatedValue(); mMatrix.reset(); mMatrix.postScale(mScaleFactor, mScaleFactor); mMatrix.postTranslate(value, 0); mImageView.setImageMatrix(mMatrix); } }); mCurrentAnimator.setDuration(DURATION); mCurrentAnimator.addListener(new AnimatorListenerAdapter() { @Override public void onAnimationEnd(Animator animation) { if(mDirection == RightToLeft) mDirection = LeftToRight; else mDirection = RightToLeft; animate(); } }); mCurrentAnimator.start(); } private void updateDisplayRect() { mDisplayRect.set(0, 0, mImageView.getDrawable().getIntrinsicWidth(), mImageView.getDrawable().getIntrinsicHeight()); mMatrix.mapRect(mDisplayRect); }}
1 0
- 像音乐播放App一样移动背景
- 背景播放音乐
- cocos2d-之音乐背景播放
- iOS app如何在进入背景模式的时候依然播放音乐
- H5,Audio音乐播放器(移动版)
- textbox把背景颜色设置成空让它像LABEL一样
- 音乐播放器app开源代码
- 自己动手实现音乐播放器app
- Nextpeer让任何移动游戏像Draw Something一样性感
- 让 Chrome 像 app 一样下拉拖拽刷新页面
- 【新技能get】让App像Web一样发布新版本
- app播放无声音乐实现app后台运行
- 短音频\音乐播放+震动(和手机来电一样震动音乐停震动停)
- Android 如何在通话中播放音乐/通话背景音
- 自己编程实现更改电脑桌面背景并同时播放音乐
- 播放pcm文件音乐不变调和正常播放MP3文件一样
- 关于移动端音乐没有自动播放的问题
- 模仿网易云音乐移动端播放器
- Android最佳实践之性能 - 提升Layout性能
- 事儿多的不要不要的----jquery事件
- angularjs自定义过滤器
- angularjs表单验证
- servlet 学习(三)
- 像音乐播放App一样移动背景
- ZeroMQ的内部架构
- 实现文本框到处弹的效果
- 常见面试之机器学习算法思想简单梳理
- 安卓热修复,android打补丁,不用发版本就能实时的解决一些线上版本的bug
- 链表之实现对二进制数的加一操作
- Android最佳实践之性能 - 多线程
- JNI - Static method. Method of SuperClass.
- Android4.4深入浅出之SurfaceFlinger总体结构