2 dxc1228 dxc1228 于 2016.03.02 12:02 提问

在onTouchEvent()时间里面加了一个scale 缩放动画效果,效果和预期不同
//设置动画属性 
  animation = new ScaleAnimation(1.0f, 0.5f, 1.0f, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f,Animation.RELATIVE_TO_SELF, 0.5f);
    animation.setDuration(500);// 设置动画持续时间
    animation.setRepeatCount(1);// 设置重复次数
    animation.setRepeatMode(Animation.REVERSE);


    //onTouchEvent()事件
    public boolean onTouchEvent(MotionEvent event) {
    switch (event.getAction() & MotionEvent.ACTION_MASK) {
        case MotionEvent.ACTION_DOWN:
            int width = iv.getWidth();
            int height = iv.getHeight();
            iv.setX(event.getX() - (width/2) );//iv是图片所在的imageView控件
            iv.setY(event.getY() - (height/2) );
            iv.startAnimation(animation);
            break;
        }
    return true;
}


就是想实现一个类似相机手动点击聚焦的动画效果,但是实际效果是在点击屏幕后动画位置能确定,但是缩放中心是变化的,并不是设置的图片的中心点,请有经验的人帮忙指出问题,多谢!

2个回答

u013147734
u013147734   2016.03.02 14:52
已采纳

因为你做动画前突然setX值等,中心不好确定了。换用ObjectAnimation或ValueAnimation吧,自己实现缩放机制
ValueAnimator valueAnimator = ValueAnimator.ofFloat(1, 0.5f);
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
float v = (Float) animation.getAnimatedValue();
ball.setScaleX(v);
ball.setScaleY(v);
}
});
valueAnimator.setDuration(500);// 设置动画持续时间
valueAnimator.setRepeatCount(1);// 设置重复次数
valueAnimator.setRepeatMode(Animation.REVERSE);
@Override
public boolean onTouch(MotionEvent event) {
switch (event.getAction() & MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN:
int width = ball.getWidth();
int height = ball.getHeight();
ball.setX(event.getX() - (width / 2));//ball是图片所在的imageView控件
ball.setY(event.getY() - (height / 2));

            ball.setPivotX(ball.getWidth() / 2f);
            ball.setPivotY(ball.getHeight() / 2f);

            valueAnimator.start();
            break;
    }
    return true;
}
dxc1228
dxc1228 刚才说的不严谨,不是去掉标题栏是设置全屏
2 年多之前 回复
dxc1228
dxc1228 去掉标题栏就好使了或者是触摸点Y轴减去标题栏的高度,缩放点Y轴减去标题栏一半的高度就可以了
2 年多之前 回复
u013147734
u013147734 你可以去掉valueAnimator.start()这句话单独调试
2 年多之前 回复
u013147734
u013147734 如果是ball是在一个蒙层上,保证蒙层大小位置与监听事件的View一致。不是父控件的原因,再考虑其他原因
2 年多之前 回复
u013147734
u013147734 回复代码在青春飞扬: 确定你的这些代码是在ball的直接父控件中调用吗,否则onTouch中参数event的XY值不能直接参考,需要修正...
2 年多之前 回复
dxc1228
dxc1228 我测试了你的方法确实管用,但是ball.setY(event.getY() - (height / 2))改为ball.setY(event.getY() - height)才能实现效果,不知道为什么,若是有时间的话帮我解答下,谢谢!
2 年多之前 回复
dxc1228
dxc1228 我测试了你的方法确实管用,但是ball.setY(event.getY() - (height / 2))改为ball.setY(event.getY() - height)才能实现效果,不知道为什么,若是有时间的话帮我解答下,谢谢!
2 年多之前 回复
w89h06q22
w89h06q22   2016.03.02 12:13

这个问题我遇到过,是因为你用错了方法。

MotionEvent里有如下两种方法(对应y轴也一样),一个是getX(),一个是getRawX()。

这两个方法是有区别的。

getX()是指当前你的手指在touch的控件上相对该控件的位置(也就是iv的位置)。当你的手指移动时,你的控件跟着移动,这个时候,你的手指和iv的相对位置又发生了变化,就会发生iv一直跳动的现象

getRawX()是你的手指相对于屏幕的位置,这个原坐标是固定的。一般要实现控件跟随,都是用此方法。

dxc1228
dxc1228 谢谢答主,楼下的答案是正解,所以我只能采纳他(她)的答案,不过从你的回答中我也学习到新知识,还是十分感谢答主的帮忙!
2 年多之前 回复
w89h06q22
w89h06q22 回复代码在青春飞扬: setX()确实是以控件左上角为基准的的,但是他是相对iv所在的父布局进行偏移。你在做偏移时不对,有可是父布局位置的问题。可以通过打印iv父布局相对屏幕左上角位置来确认。
2 年多之前 回复
dxc1228
dxc1228 我理解的是设置控件的左上角坐标显示在屏幕中
2 年多之前 回复
dxc1228
dxc1228 再多问一句,就是我把上面代码中iv.setY(event.getY() - (height/2) )改为iv.setY(event.getY() - height );才能达到点击哪里图片中心显示在哪里的效果。不太明白setX()和setY()方法的用法了,我理解的是
2 年多之前 回复
dxc1228
dxc1228 再多问一句,就是我把上面代码中iv.setY(event.getY() - (height/2) )改为iv.setY(event.getY() - height );才能达到点击哪里图片中心显示在哪里的效果。不太明白setX()和setY()方法的用法了,我理解的是
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
Android 的ScaleAnimation 缩放动画基本运用
因为今天用到了ScaleAnimation缩放动画就写一下,加深一下印象。用ScaleAnimation有几个重载方法,这里就将八个参数的重载方法。 ScaleAnimation(float fromX, float toX, float fromY, float toY,int pivotXType, float pivotXValue, int pivotYType, float pivot
Layout的放大和缩小效果例子(ScaleAnimation)
个Layout从中心放大和缩小的例子,直接上代码: 1.ScaleDialog.java文件 Java代码  package cn.com;      import android.app.Activity;   import android.graphics.drawable.Drawable;   import android.os.Bundle;   import android.widge
【CSS3】变形--缩放 scale()
缩放 scale()函数 让元素根据中心原点对对象进行缩放。 缩放 scale 具有三种情况: 1、 scale(X,Y)使元素水平方向和垂直方向同时缩放(也就是X轴和Y轴同时缩放) 例如: div:hover { -webkit-transform: scale(1.5,0.5);   -moz-transform:scale(1.5,0.5) transfo
Button点击缩放动画效果
自定义Button实现button点击缩放动画效果 public class  ScaleButton extends Button {    private Context context;      public  ScaleButton(Context context) {       this(context, null);       this.context = co
css3 2D--transform--scale缩放
再来说说css3 2Dtransform之scale,    该属性理解也很简单,可以让元素在水平和垂直方向进行缩放,请注意缩放这个词语,说明它是既可以将元素方法,也可以将元素缩小的。该属性的用法如下:    transform:scale(水平缩放比例,垂直缩放比例)//注意是缩放比例,是不用带单位的,表示元素的宽高*对应的比例即为缩放的具体值。    直接上代码:
css3 scale 放大有重影
解决方法: 先缩小再还原 看起来像是放大了 css3 动画手机上无法运行  解决方法 @-webkit-keyframes myfirst 加上前缀webkit
自定义ViewPager的切换动画ScalePageTransformer
自定义PageTransformer实现类似Gallery效果
利用重写onTouchEvent方法实现view随手指移动效果
view随手指移动的多种实现方法
cocos2d-x动作、特效和动画(二)缩放动作
缩放动作类主要有两个方法CCScaleTo和CCScaleBy两种,同(一)中一样,CCScaleTo是直接缩放到相应比例,CCScaleBy是在目前基础上缩放相应的比例。 //由于我原图大小太大,已经缩放过了一次(0.25),为了方便运行结果,所以actionBy1和actionBy2的缩放比例都是2.f (也就是 0.25*2=0.5,同actionTo1的效果差不多) CCActionI
ios 缩放动画
- (void)hiddenAction{ // 表示view的原来尺寸 self.layer.transform = CATransform3DMakeScale(1, 1, 1); [UIView animateWithDuration:0.5 animations:^{ // 按照比例scalex=0.001,y=0.001进行缩小 se