如何解决使用Android标准动画显示硬币的正反两面
| 我非常接近要使用“硬币翻转”动画,但是由于当前动画系统中的限制(错误?),我无法找到一种方法来展示硬币翻转的两个侧面。 例如,我有以下Animation .XML:<?xml version=\"1.0\" encoding=\"utf-8\"?>
<set xmlns:android=\"http://schemas.android.com/apk/res/android\"
android:shareInterpolator=\"false\">
<scale
android:repeatCount=\"17\"
android:repeatMode=\"reverse\"
android:interpolator=\"@android:anim/accelerate_decelerate_interpolator\"
android:fromXScale=\"1.0\" android:toXScale=\"1.0\"
android:fromYScale=\"1.0\" android:toYScale=\"0.0\"
android:pivotX=\"50%\" android:pivotY=\"50%\"
android:fillEnabled=\"true\"
android:fillAfter=\"true\"
android:duration=\"60\"
/>
<scale
android:repeatCount=\"1\"
android:repeatMode=\"reverse\"
android:interpolator=\"@android:anim/accelerate_decelerate_interpolator\"
android:fromXScale=\"1.0\" android:toXScale=\"2.0\"
android:fromYScale=\"1.0\" android:toYScale=\"2.0\"
android:pivotX=\"50%\" android:pivotY=\"50%\"
android:fillEnabled=\"true\"
android:fillAfter=\"true\"
android:duration=\"800\"
/>
<translate
android:repeatCount=\"1\"
android:repeatMode=\"reverse\"
android:interpolator=\"@android:anim/accelerate_decelerate_interpolator\"
android:fromXDelta=\"0%\"
android:toXDelta=\"0%\"
android:fromYDelta=\"0%\"
android:toYDelta=\"-150%\"
android:fillEnabled=\"true\"
android:fillAfter=\"true\"
android:duration=\"800\"
/>
</set>
通过在Y轴上缩放硬币并在循环中将其反转来“伪造”一种翻转动画。与此结合的是,有一个比例可以使整体动画更大,同时还要上下转换。但这只会显示硬币的一面。
我尝试让两个动画同时运行,但硬币的每一面都同时运行,但是由于REPEATCOUNT在应用于AnimationSet时不起作用,因此无法找到使它们交错的方法。否则,我可以在一个动画之后(在另一个动画之前)引入某种延迟,以便它们交替出现,给人以抛硬币的错觉。
有谁知道我可以做些什么来调整以获得期望的结果?
我曾想过放弃并做一个基于帧的动画(将翻转预渲染为帧),但是看来您无法混合“帧与补间”动画,所以我会丢失翻转“高度”和“距离”效果。
(关于硬币着陆,我还有另一个问题-例如,最终结果是随机的,但我希望我可以在最后输入实际结果吗?)
提前致谢!
解决方法
此代码显示相同的过程
http://www.inter-fuser.com/2009/08/android-animations-3d-flip.html
,我自己一直在寻找类似的东西,即使图像具有缩放比例,因此看来imageview越来越靠近屏幕。
我将您的动画与该解决方案结合起来,可以精确地完成您想要的事情,并且它相当轻巧,从而不需要多个视图。
https://github.com/Lojko/Booty/blob/master/src/game/booty/BootyGameActivity.java
原始链接的位置已更改:http://www.jasoncavett.com/2011/05/changing-images-during-an-android-animation/#comments
参见FlipCoin类及其用法,我已经有一个动画(以与链接详细说明相同的方式创建)
,我最近想为一个项目实现这样的事情。我终于想出了一个解决方案,结果足够好。希望它对尝试实现相同动画的其他人有所帮助。
我将结果作为要点上传到了GitHub。
要预览动画,请单击此处。
有关完整的android studio项目的信息,请访问我们的CoinToss存储库。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。