1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 自定义Animation 3D动画旋转【HTML】

自定义Animation 3D动画旋转【HTML】

时间:2023-12-31 00:29:10

相关推荐

自定义Animation 3D动画旋转【HTML】

web前端|html教程

自定义Animation、3D动画旋转

web前端-html教程

/**

比特币对冲系统源码,ubuntu安装中途卡,tomcat7源码分析,樟树黑色爬虫,株洲php编程培训机构,seo基因lzw

* 自定义动画,利用Camera可以实现3D效果 在Activity中调用一下方法 image = (ImageView)

网易新闻ios源码,ubuntu关闭ssl,tomcat是jsp运行吗,爬虫和股市,php外包公司知乎,seo万词霸屏系统多少钱lzw

* findViewById(R.id.image) ; Bitmap bitmap =

取框架网页源码模块,ubuntu 启动锁屏,tomcat突然跑不起来,京东页面爬虫,长沙黑马php培训,抖音seo第一团队火推联盟lzw

* BitmapFactory.decodeResource(getResources(), R.drawable.main_back_pic) ;

* image.setImageBitmap(bitmap); image.startAnimation(new

* MyAnimation(bitmap.getWidth()/2, bitmap.getHeight()/2, 3500));

* */

public class MyAnimation extends Animation {

private int width;

private int height;

private int duration;// 持续的时间

private Camera camera = new Camera();

public MyAnimation(int width, int height, int duration) {

this.height = height;

this.width = width;

this.duration = duration;

}

@Override

public void initialize(int width, int height, int parentWidth,

int parentHeight) {

setDuration(duration);// 设置动画的执行时间

setFillAfter(true);// 动画结束后动画停留在动画的最后一帧,setFillBefore(true):动画结束后停留在第一帧

// 动画设置成匀速运动,设置运动状态,在XML文件里设置没有作用,必须用在Java代码中设置

setInterpolator(new LinearInterpolator());

super.initialize(width, height, parentWidth, parentHeight);

}

@Override

protected void applyTransformation(float interpolatedTime,

Transformation trans) {

/**

* 此方法中的两个参数,第一个interpolatedTime,代表了抽象动画进行的时间,不管时间进行多久,其参数数值都是从0到1

* 0代表动画开始,1代表动画结束, Transformation是对动画所做的改变 Camera提供的方法:getMatrix(Matrix

* matrix)将Camera所做的变化应用到matrix上 rotateX(float deg)将目标组件沿着X轴进行旋转

* rotateY(float deg)将目标组件沿着Y轴进行旋转 totateZ(float deg)将组件沿着Z轴进行旋转

* translate(float x,float y,float z)将目标组件在三维空间内进行位移转换

* applyToCanvas(Canvas canvas)把Camera所做的变化应用到Canvas

* */

super.applyTransformation(interpolatedTime, trans);

camera.save();

// 把目标组件在三维视图中进行切换

// 在第一次调用的时候nterpolatedTime的值为0,相当于把view移动了10个像素,以后越来越少,一个周期过去,再变向转动

camera.translate(0.0f, 0.0f, (10 – 10 * interpolatedTime));

// camera.rotateX(360 * interpolatedTime);

camera.rotateY(360 * interpolatedTime);

// camera.rotateZ(360 * interpolatedTime);

Matrix matrix = trans.getMatrix();

camera.getMatrix(matrix);

// preTranslate是指在setScale前,平移,postTranslate是指在setScale后平移

// 注意他们参数是平移的距离,而不是平移目的地的坐标!

// 由于缩放是以(0,0)为中心的,所以为了把界面的中心与(0,0)对齐,就要preTranslate(-centerX,

// -centerY),

// setScale完成后,调用postTranslate(centerX,

// centerY),再把图片移回来,这样看到的动画效果就是activity的界面图片从中心不停的缩放了

// centerX和centerY是界面中心的坐标

matrix.preTranslate(-width, -height);

matrix.postTranslate(width, height);

camera.restore();

}

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。