挑戦する
すべての一般的なブラウザでAPNGを表示します。
![](https://habrastorage.org/storage1/7ed2bce7/231b96f5/ace847d7/c78a152f.png)
解決策
Firefox、Opera、およびWebKitでAnimated PNGアイデアを使用していますか? 簡単! フレームも変更しますが、cssを使用すると、すべての一般的なブラウザーでメソッドを実装できます。
画像の準備
最も興味深いのは、PhotoshopがAPNGを理解しないという事実から始まります。この問題を解決するために、私はJapngエディターを選択しました。 このプログラムはJAVAで書かれており、インストールされたバージョンのJAVA 6が必要です。2つの主なタスクを解決します。フレームをAPNGに、またはその逆に変換します。
こちらからダウンロードできます。
![](https://habrastorage.org/storage1/7b2dd5a7/082996b5/dcf80fed/d1dbb61c.jpg)
完成した画像
![](https://habrastorage.org/storage1/23f0d0f4/61944ec6/871774fb/7bb1a6b9.png)
HTML
<div class="ajax-loader"><div>
CSS
.ajax-loader { width: 30px; /* */ height: 30px; /* */ background: url('ajax-loader.png') no-repeat; /* */ }
jquery.aimg.js
(function ($) { $.fn.aimg = function (options) { options = $.extend({}, { speed: 150 }, options); return this.each(function () { var $el = $(this), $img = $('<img src="' + $(this).css('backgroundImage').replace(/(^url)|(["'()])/g, '') + '" style="position: absolute; left: -99999px;">'), currFrame = 1, slides; $img.load(function () { slides = $(this).width() / $el.width(); $(this).remove(); startAnimation(); }); $('body').append($img); function startAnimation() { return setInterval(function () { $el.css('backgroundPosition', '-' + currFrame * $el.width() + 'px 0px'); if (currFrame == slides) { $el.css('backgroundPosition', '0px 0px'); currFrame = 0; } currFrame++; }, options.speed); } }); } })(jQuery);
jsFiddleの例