【发布时间】:2019-05-21 06:29:21
【问题描述】:
我正在尝试使用 SVG 创建一个下降的俄罗斯方块块的动画,其中包括平移和旋转该块。我对每一个动作都使用了单独的动画,所以它们看起来尽可能接近游戏。下降的动画有效,但是一旦我尝试旋转该部分,它就不会保持旋转并在下一步移动时恢复到原始旋转 (0)。有什么方法可以让这件作品保持旋转,或者甚至是我可以实现动画的更好方法?
提前感谢您的帮助。
<svg id="svg" xmlns="http://www.w3.org/2000/svg" width="280" height="504" xmlns:xlink="http://www.w3.org/1999/xlink">
<defs>
<g id ="b_lightblue">
<rect x="20" y="20" width="20" height="20" fill="#00F0F0"/>
<polyline points="20 20, 16 16, 44 16, 40 20, 20 20" fill="#B3FBFB"/>
<polyline points="40 20, 44 16, 44 44, 40 40, 40 20" fill="#00D8D8"/>
<polyline points="40 40, 44 44, 16 44, 20 40, 40 40" fill="#007878"/>
<polyline points="20 40, 16 44, 16 16, 20 20, 20 40" fill="#00D8D8" />
</g>
<g id ="tetro_I">
<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#b_lightblue" transform="translate(-16 -16)"/>
<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#b_lightblue" transform="translate(12 -16)"/>
<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#b_lightblue" transform="translate(40 -16)"/>
<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#b_lightblue" transform="translate(68 -16)"/>
</g>
</defs>
<rect x="0" y="0" width="280" height="504" fill="#CDCEAE"/> <!--Background-->
<use id="tetro_1" xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#tetro_I" transform="translate(84 28) rotate(0)" opacity="1"/> <!--Tetris Piece-->
<animateTransform xlink:href="#tetro_1" id="t1_move_1" attributeName="transform" type="translate" begin="0.8s" dur="0.02" from="84 28" to="84 65" fill="freeze"/>
<animateTransform xlink:href="#tetro_1" id="t1_move_2" attributeName="transform" type="translate" additive="sum" begin="t1_move_1.end+0.8s" dur="0.02" to="84 65" fill="freeze"/>
<animateTransform xlink:href="#tetro_1" id="t1_move_3" attributeName="transform" type="translate" additive="sum" begin="t1_move_2.end+0.8s" dur="0.02" to="84 93" fill="freeze"/>
<animateTransform xlink:href="#tetro_1" id="t1_rotate_1" attributeName="transform" type="rotate" additive="sum" begin="t1_move_3.end+0.2s" dur="0.001" from="0" to="90 56 0" fill="freeze"/>
<animateTransform xlink:href="#tetro_1" id="t1_move_4" attributeName="transform" type="translate" additive="sum" begin="t1_move_3.end+0.8s" dur="0.02" to="84 121" fill="freeze"/>
</svg>
【问题讨论】:
标签: animation svg svg-animate smil