Google Doodle如何运作?
当我搜索它时,我发现了
哪一个是正确的?
答案 0 :(得分:3)
首先,它们将<img>
标记JPEG与所有动画帧一起包含在<div>
标记内,该标记具有182像素的固定高度并隐藏溢出。这样可以创建一个固定的窗口,它可以屏蔽除当前动画帧之外的所有窗口。图像使用JavaScript进行动画处理,这会更改绝对定位图像的top
属性,以使用setTimeout()
函数将其向上滑动固定的间隔。
以下是Google推荐的一些示例代码:
<div style="height:182px;position:relative;width:468px;overflow:hidden">
<img border="0" src="source.jpg" id="filmstrip" style="position: absolute; height: 2912px; top: -0px; display: block; ">
</div>
<强> Jquery的:强>
<script>
function naiveAnimation(id) {
var img = document.getElementById(id);
var offset = 0;
var animate = function() {
//slide the image correct frame of animation given by offset
img.style.top = -offset + "px";
//calculate offset to next frame
offset = Math.floor(offset + 182);
//if we are not yet on the last frame...
if(offset < 2912) {
//call me again in half a second
window.setTimeout(animate, 500);
} else {
//at last frame, so all done!
}
};
//start the animation
animate();
}
naiveAnimation('filmstrip');
</script>
答案 1 :(得分:0)
我会选择Animated JPEG
和Canvas
,但APNG
也可以。我还没有看到涂鸦上的256位彩色图像。甚至可能是webm
。有些涂鸦有声,有些是互动的,所以我认为它们会使用他们认为适合其目的的任何东西。