Android 安卓动画 属性动画 - 缩放动画(1)

本文介绍了如何在Android应用中使用ObjectAnimator进行属性动画,如scaleX操作,以及不同动画效果的创建方法。作者分享了自己的职业经历,并提供了一份全面的Android开发学习资料,旨在帮助开发者系统学习和提升技能,减轻学习压力。
摘要由CSDN通过智能技术生成

android:textColor=“#fff” />

<LinearLayout

android:layout_width=“match_parent”

android:layout_height=“0dp”

android:layout_weight=“4”

android:orientation=“vertical”>

<ImageView

android:id=“@+id/image”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:layout_gravity=“center”

android:layout_marginTop=“20dp”

android:background=“@mipmap/kuiba” />

<TextView

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:layout_gravity=“center”

android:text=“《魁拔》”

android:textSize=“18sp” />


代码逻辑 篇


属性动画用到的是:ObjectAnimator

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

ObjectAnimator objectAnimator;

private Button button;

private ImageView image;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initView();

}

private void initView() {

button = (Button) findViewById(R.id.button);

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

button.setOnClickListener(this);

image.setOnClickListener(this);

}

@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.button:

objectAnimator = ObjectAnimator.ofFloat(image,“scaleX”,2f);

objectAnimator.setDuration(2000);

objectAnimator.start();

break;

case R.id.image:

Toast.makeText(this, “我是属性动画”, Toast.LENGTH_SHORT).show();

break;

}

}

}

AndroidStudio快速实例化-插件安装与使用:https://blog.csdn.net/qq_40881680/article/details/82012180


objectAnimator = ObjectAnimator.ofFloat(image,“scaleX”,2f);

沿着X轴放大两倍,效果只有一次


objectAnimator = ObjectAnimator.ofFloat(image,“scaleX”,1f,2f);

沿着X轴放大两倍效果


objectAnimator = ObjectAnimator.ofFloat(image,“scaleX”,1f,2f,1f);

沿着X轴放大两倍效果,然后再回到初始大小


ObjectAnimator.ofFloat()括号中的参数:

第一个参数,要实现动画的控件id

第二个参数,要实现的动画属性,以下列出6种:

|

propertyName

| 详细作用 |

| — | — |

| alpha | 实现渐变效果 |

| rotation | 实现旋转旋转效果 |

| translationX | 实现水平移动效果(左或右移动) |

| translationY | 实现纵向移动效果(向上或者向下移动) |

| scaleX | 实现轴X缩放效果(放大或者缩小) |

| scaleY | 实现轴Y缩放效果(放大或者缩小) |

后面的参数就不多做解释了,以上都有

Y轴同理,将第二个参数改为scaleY即可

若想要实现X,Y轴同时缩放,可以参照属性 动画-组合动画

效果演示 篇


沿着X轴放大两倍,效果只有一次


沿着X轴放大两倍效果


沿着X轴放大两倍效果,然后再回到初始大小

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

给大家送上我成功跳槽复习中所整理的资料,由于文章篇幅有限,所以只是把题目列出来了

image

image

image

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

最后

给大家送上我成功跳槽复习中所整理的资料,由于文章篇幅有限,所以只是把题目列出来了

[外链图片转存中…(img-0kSTf8Xg-1712680834729)]

[外链图片转存中…(img-muhR9DzL-1712680834729)]

[外链图片转存中…(img-S0ByypFJ-1712680834729)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 21
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android ConstraintLayout可以通过缩放动画实现视图的放大或缩小效果。可以使用属性动画或者逐帧动画来实现缩放动画效果。 以下是使用属性动画实现缩放动画的示例代码: ```java // 导入必要的类 import android.animation.ObjectAnimator; import android.view.View; // 获取要进行缩放动画的视图 View view = findViewById(R.id.your_view_id); // 创建X轴方向的缩放动画 ObjectAnimator scaleXAnimator = ObjectAnimator.ofFloat(view, "scaleX", 1.0f, 2.0f); scaleXAnimator.setDuration(1000); // 设置动画持续时间为1秒 // 创建Y轴方向的缩放动画 ObjectAnimator scaleYAnimator = ObjectAnimator.ofFloat(view, "scaleY", 1.0f, 2.0f); scaleYAnimator.setDuration(1000); // 设置动画持续时间为1秒 // 同时播放X轴和Y轴的缩放动画 AnimatorSet animatorSet = new AnimatorSet(); animatorSet.playTogether(scaleXAnimator, scaleYAnimator); animatorSet.start(); ``` 以上代码中,首先通过findViewById方法获取要进行缩放动画的视图,然后使用ObjectAnimator类创建X轴和Y轴方向的缩放动画,设置动画的起始值和结束值,以及动画的持续时间。最后使用AnimatorSet类将两个缩放动画同时播放。 另外,还可以使用逐帧动画实现缩放动画。逐帧动画是一系列静态图片按照一定的时间间隔连续播放,从而形成动画效果。可以通过在res/drawable目录下创建xml文件来定义逐帧动画。 以下是使用逐帧动画实现缩放动画的示例代码: 1. 在res/drawable目录下创建scale_animation.xml文件,内容如下: ```xml <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false"> <item android:drawable="@drawable/scale_frame1" android:duration="100" /> <item android:drawable="@drawable/scale_frame2" android:duration="100" /> <item android:drawable="@drawable/scale_frame3" android:duration="100" /> <!-- 添加更多的帧图片 --> </animation-list> ``` 2. 在res/drawable目录下创建scale_frame1.png、scale_frame2.png、scale_frame3.png等图片文件,作为逐帧动画的帧图片。 3. 在布局文件中添加一个ImageView视图,并设置其背景为scale_animation.xml: ```xml <ImageView android:id="@+id/animation_view" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/scale_animation" /> ``` 4. 在代码中获取ImageView视图,并启动逐帧动画: ```java ImageView imageView = findViewById(R.id.animation_view); AnimationDrawable animationDrawable = (AnimationDrawable) imageView.getBackground(); animationDrawable.start(); ``` 以上代码中,首先通过findViewById方法获取ImageView视图,然后将其背景设置为scale_animation.xml,最后通过AnimationDrawable类获取逐帧动画对象,并启动动画

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值