gpt4 book ai didi

android - 使用图像的椭圆路径动画

转载 作者:太空宇宙 更新时间:2023-11-03 13:49:03 28 4
gpt4 key购买 nike

我正在尝试实现椭圆路径动画,我想使用图像显示路径动画,我尝试了 https://github.com/matthewrkula/AnimatedPathView但它不适用于椭圆形。我还尝试了下面的椭圆形路径代码,但它显示的是圆圈,有人有想法吗?提前致谢!!!

我的动画.java

public class MyAnimation extends Animation {

private View view;
private float cx, cy; // center x,y position of circular path
private float prevX, prevY; // previous x,y position of image during animation
private float r; // radius of circle
private float prevDx, prevDy;


/**
* @param view - View that will be animated
* @param r - radius of circular path
*/
public MyAnimation(View view, float r){
this.view = view;
this.r = r;
}

@Override
public boolean willChangeBounds() {
return true;
}

@Override
public void initialize(int width, int height, int parentWidth, int parentHeight) {
// calculate position of image center
int cxImage = width / 2;
int cyImage = height / 1;
cx = view.getLeft() + cxImage;
cy = view.getTop() + cyImage;

// set previous position to center
prevX = cx;
prevY = cy;
}

@Override
protected void applyTransformation(float interpolatedTime, Transformation t) {
if(interpolatedTime == 0){
t.getMatrix().setTranslate(prevDx, prevDy);
return;
}

float angleDeg = (interpolatedTime * 360f + 90) % 360;
float angleRad = (float) Math.toRadians(angleDeg);

// r = radius, cx and cy = center point, a = angle (radians)
float x = (float) (cx + r * Math.cos(angleRad));
float y = (float) (cy + r * Math.sin(angleRad));


float dx = prevX - x;
float dy = prevY - y;

prevX = x;
prevY = y;

prevDx = dx;
prevDy = dy;


t.getMatrix().setTranslate(dx, dy);
}
}

路径动画.java

image = (ImageView) findViewById(R.id.image);

image.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Animation anim = new MyAnimation(image, 300);
anim.setDuration(1000);
image.startAnimation(anim);
}
});

最佳答案

在多次尝试使用这个自定义类后,我找到了解决方案

动画 View .java

public class AnimationView extends View {

Paint paint;
long animationDuration = 10000;
int framesPerSecond = 60;
Bitmap bm;
int bm_offsetX, bm_offsetY;

Path animPath;
PathMeasure pathMeasure;
float pathLength;

float step; //distance each step
float distance; //distance moved

float[] pos;
float[] tan;

Matrix matrix;

public AnimationView(Context context) {
super(context);
initMyView();
}

public AnimationView(Context context, AttributeSet attrs) {
super(context, attrs);
initMyView();
}

public AnimationView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
initMyView();
}

@TargetApi(Build.VERSION_CODES.LOLLIPOP)
public void initMyView(){
paint = new Paint();
paint.setColor(Color.RED);
paint.setStrokeWidth(5);
paint.setStyle(Paint.Style.STROKE);

bm = BitmapFactory.decodeResource(getResources(), R.mipmap.ic_launcher);
bm_offsetX = bm.getWidth()/2;
bm_offsetY = bm.getHeight()/2;
animPath = new Path();
animPath.moveTo(100, 100);

animPath.addArc(new RectF(1, 100, 300, 600), 1, 800);
animPath.close();

pathMeasure = new PathMeasure(animPath, false);
pathLength = pathMeasure.getLength();

Toast.makeText(getContext(), "pathLength: " + pathLength, Toast.LENGTH_LONG).show();

step = 1;
distance = 0;
pos = new float[2];
tan = new float[2];

matrix = new Matrix();
}

@Override
protected void onDraw(Canvas canvas) {
canvas.drawPath(animPath, paint);
if(distance < pathLength){
pathMeasure.getPosTan(distance, pos, tan);

matrix.reset();
float degrees = (float)(Math.atan2(tan[1], tan[0])*180.0/Math.PI);
matrix.postRotate(degrees, bm_offsetX, bm_offsetY);
matrix.postTranslate(pos[0]-bm_offsetX, pos[1]-bm_offsetY);
canvas.drawBitmap(bm, matrix, null);
distance += step;
}else{
distance = 0;
}
invalidate();
}
}

并写入xml

<com.example.android.mydemo.animation.pathanimation.AnimationView
android:layout_width="match_parent"
android:layout_height="450dp" />

关于android - 使用图像的椭圆路径动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37384508/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com