首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何允许ImageView的大小随AnimationDrawable的不同而变化?

要实现ImageView的大小随AnimationDrawable的不同而变化,可以通过以下步骤实现:

  1. 创建一个AnimationDrawable对象,并添加帧动画资源。AnimationDrawable animationDrawable = new AnimationDrawable(); animationDrawable.addFrame(getResources().getDrawable(R.drawable.frame1), 100); animationDrawable.addFrame(getResources().getDrawable(R.drawable.frame2), 100); // 添加更多帧动画资源...
  2. 设置AnimationDrawable作为ImageView的背景,并启动动画。ImageView imageView = findViewById(R.id.imageView); imageView.setBackground(animationDrawable); animationDrawable.start();
  3. 监听AnimationDrawable的动画帧变化事件,并在每一帧变化时更新ImageView的大小。animationDrawable.setOneShot(false); // 设置循环播放 animationDrawable.setCallback(new Drawable.Callback() { @Override public void invalidateDrawable(Drawable who) { // 动画帧变化时回调 imageView.setImageDrawable(who); // 根据当前帧的大小更新ImageView的大小 imageView.setLayoutParams(new LinearLayout.LayoutParams(who.getIntrinsicWidth(), who.getIntrinsicHeight())); } @Override public void scheduleDrawable(Drawable who, Runnable what, long when) {} @Override public void unscheduleDrawable(Drawable who, Runnable what) {} });

这样,当AnimationDrawable播放动画时,ImageView的大小会根据每一帧的大小进行自动调整。

推荐的腾讯云相关产品:腾讯云移动直播(https://cloud.tencent.com/product/lvb)可以用于实时音视频直播,适用于直播、在线教育、互动娱乐等场景。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

11分2秒

1.13.同x不同y和同y不同x,求私钥

1分32秒

最新数码印刷-数字印刷-个性化印刷工作流程-教程

13分1秒

产业安全专家谈 | 数字营销浪潮下,企业如何打赢流量反欺诈攻防战?

10分19秒

Emoji表情不够用?两个表情合成出新表情: 复刻Emojimix算法实现

1分3秒

振弦传感器测量原理详细讲解

21秒

常用的振弦传感器种类

1分30秒

基于强化学习协助机器人系统在多个操纵器之间负载均衡。

领券