<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>jp.ferv.blog &#187; PNGEncoder</title>
	<atom:link href="http://ferv.jp/blog/tag/pngencoder/feed/" rel="self" type="application/rss+xml" />
	<link>http://ferv.jp/blog</link>
	<description>「ActionScriptは素晴らしい。コンパイルする価値がある。」って偉い人が言ってた。</description>
	<lastBuildDate>Sun, 15 Aug 2010 00:42:34 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9</generator>
	<language>ja</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>最速 PNGEncoder を教えてもらったよ</title>
		<link>http://ferv.jp/blog/2010/08/15/fastest-pngencoder/</link>
		<comments>http://ferv.jp/blog/2010/08/15/fastest-pngencoder/#comments</comments>
		<pubDate>Sat, 14 Aug 2010 17:13:44 +0000</pubDate>
		<dc:creator>dsk</dc:creator>
				<category><![CDATA[Web]]></category>
		<category><![CDATA[ActionScript 3.0]]></category>
		<category><![CDATA[FileFormat]]></category>
		<category><![CDATA[PNGEncoder]]></category>

		<guid isPermaLink="false">http://ferv.jp/blog/?p=1416</guid>
		<description><![CDATA[Quick tip: Fastest ActionScript PNGEncoder at Jozef Chúťka&#8217;s blog で PNGEncoder の処理速度比較してます。Optimized PNG [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://blog.yoz.sk/2010/06/quick-tip-fastest-actionscript-pngencoder/">Quick tip: Fastest ActionScript PNGEncoder at Jozef Chúťka&#8217;s blog</a> で PNGEncoder の処理速度比較してます。<a href="http://ferv.jp/blog/2010/01/08/optimized-pngencoder-with-filters/">Optimized PNGEncoder with filters</a> で最適化を試してたコードが dsk.PNGEncoder ってのでエントリしてます。</p>
<p>結果は by.blooddy.crypto.image.PNG24Encoder が圧倒的に最速！！
エントリ内からのリンクが切れてるので、使ってみたい方は <a href="http://www.blooddy.by/en/">BlooDHounD&#8217;s workspace</a> の blooddy_crypto.swc からダウンロードして下さい。</p>
<p>透明・不透明共に速い速い！Alchemy 使ってるのか気になるところです。</p>
]]></content:encoded>
			<wfw:commentRss>http://ferv.jp/blog/2010/08/15/fastest-pngencoder/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Alchemy PNG encoder のデモ</title>
		<link>http://ferv.jp/blog/2010/02/04/alchemy-png-encoder-demo/</link>
		<comments>http://ferv.jp/blog/2010/02/04/alchemy-png-encoder-demo/#comments</comments>
		<pubDate>Wed, 03 Feb 2010 20:55:11 +0000</pubDate>
		<dc:creator>dsk</dc:creator>
				<category><![CDATA[Web]]></category>
		<category><![CDATA[ActionScript 3.0]]></category>
		<category><![CDATA[Alchemy]]></category>
		<category><![CDATA[FileReference]]></category>
		<category><![CDATA[PNGEncoder]]></category>

		<guid isPermaLink="false">http://ferv.jp/blog/?p=1214</guid>
		<description><![CDATA[dsk/PNG &#8211; Spark project の /src/sample にある二種類デモをパブリッシュした swf を張っておきます。
同期処理でエンコード

zlib 圧縮率を 1 で、不透明な画 [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.libspark.org/wiki/dsk/PNG">dsk/PNG &#8211; Spark project</a> の /src/sample にある二種類デモをパブリッシュした swf を張っておきます。</p>
<h2>同期処理でエンコード</h2>
<p><a rel="shadowbox;width=500;height=400;" href='http://ferv.jp/blog/wp-content/uploads/2010/02/PNGEncodeSync.swf'><img src="http://ferv.jp/blog/wp-content/uploads/2010/02/PNGEncodeSync.png" title="PNGEncodeSync" width="465" height="150" class="alignnone size-full wp-image-1034" /></a></p>
<p>zlib 圧縮率を 1 で、不透明な画像と透明な画像に対してフィルタの種類を変えてエンコードしてみる。</p>
<h2>非同期処理でエンコード</h2>
<p><a rel="shadowbox;width=500;height=400;" href='http://ferv.jp/blog/wp-content/uploads/2010/02/PNGEncodeAsync.swf'><img src="http://ferv.jp/blog/wp-content/uploads/2010/02/PNGEncodeAsync.png" alt="PNGEncodeAsync" title="PNGEncodeAsync" width="465" height="150" class="alignnone size-full wp-image-1034" /></a></p>
<p>非同期処理の注目点は、この例だと 12 回一気にコールしてるんだけど最後にコールしたところから順々に実行され、一個処理が終わると次の処理って感じにお行儀よく処理されていく。
これは Alchemy の機能だと思うんだけどコールしたのと逆順なのはなんか理由があるのかな・・・</p>
<p>あと、こっちはエンコード終了時に toXML() メソッドでちょっとだけデコードして情報を抜き出した XML を trace() してるから Firefox で FlashTracer 入れてる人は開いてみるといいかも。</p>]]></content:encoded>
			<wfw:commentRss>http://ferv.jp/blog/2010/02/04/alchemy-png-encoder-demo/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Alchemy PNG encoder を Spark</title>
		<link>http://ferv.jp/blog/2010/02/03/alchemy-png-encoder-spark/</link>
		<comments>http://ferv.jp/blog/2010/02/03/alchemy-png-encoder-spark/#comments</comments>
		<pubDate>Wed, 03 Feb 2010 11:29:07 +0000</pubDate>
		<dc:creator>dsk</dc:creator>
				<category><![CDATA[Web]]></category>
		<category><![CDATA[ActionScript 3.0]]></category>
		<category><![CDATA[Alchemy]]></category>
		<category><![CDATA[FileFormat]]></category>
		<category><![CDATA[PNGEncoder]]></category>

		<guid isPermaLink="false">http://ferv.jp/blog/?p=1206</guid>
		<description><![CDATA[高速化に繋がらなくて一度は捨てかけた Alchemy + libpng + zlib の PNG エンコーダを Spark した。
使い方とか svn の URL は dsk/PNG &#8211; Spark pro [...]]]></description>
			<content:encoded><![CDATA[<p>高速化に繋がらなくて一度は捨てかけた Alchemy + libpng + zlib の PNG エンコーダを Spark した。
使い方とか svn の URL は <a href="http://www.libspark.org/wiki/dsk/PNG">dsk/PNG &#8211; Spark project</a> から。</p>
<p>拾った理由は、こんな感じ。
AS3 では ByteArray.compress() メソッドを叩くと、 deflate 圧縮して zlib 形式にフォーマットしてくれるんだけど、
冗長性のない ByteArray の圧縮は高速に処理できるけど、 PNG フォーマットに定義されているフィルタ処理で冗長化してから compress() すると処理にやたらと時間がかかる。
フィルタリングする前提だと、 zlib 圧縮率を低めにすれば十分高速に処理でき、 zlib 圧縮率よりもフィルタリングの有無の方がファイルサイズ縮小のメリットが大きいけど、 compress() メソッドでは zlib 圧縮率を設定できない。
あとは、 Alchemy だと非同期に処理するコードも簡単に書けるから、大きなサイズの BitmapData をエンコードする場合などもメリットありそうだし。</p>
<p>Alchemy の非同期処理は進捗とかを関数の参照渡しで C から AS の関数をコールして通知するんだけど、これって AS3 ライクじゃないんでイベントを発行する形にラップしてある。
あと、デバッグ用にちょっとだけデコードしてチャンクの情報とかを XML にして返す関数も実装。</p>

]]></content:encoded>
			<wfw:commentRss>http://ferv.jp/blog/2010/02/03/alchemy-png-encoder-spark/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Alchemy PNG encoder</title>
		<link>http://ferv.jp/blog/2010/01/20/alchemy-png-encoder/</link>
		<comments>http://ferv.jp/blog/2010/01/20/alchemy-png-encoder/#comments</comments>
		<pubDate>Tue, 19 Jan 2010 17:46:04 +0000</pubDate>
		<dc:creator>dsk</dc:creator>
				<category><![CDATA[Web]]></category>
		<category><![CDATA[ActionScript 3.0]]></category>
		<category><![CDATA[Alchemy]]></category>
		<category><![CDATA[FileFormat]]></category>
		<category><![CDATA[PNGEncoder]]></category>

		<guid isPermaLink="false">http://ferv.jp/blog/?p=1190</guid>
		<description><![CDATA[
てことで、 zlib と libpng を使って、 Alchemy で PNG クラスを作ってみた。サンプルの一番下に該当。
PNG フォーマットには圧縮効率を上げるフィルタという仕組みがあって、フィルタの仕組み自 [...]]]></description>
			<content:encoded><![CDATA[<p><a rel="shadowbox;width=530;height=560;" href='http://ferv.jp/blog/wp-content/uploads/2010/01/PNGSample.swf'><img src="http://ferv.jp/blog/wp-content/uploads/2010/01/PNGSample.png" alt="PNGSample" title="PNGSample" width="465" height="150" class="alignnone size-full wp-image-1034" /></a></p>
<p>てことで、 <a href="http://zlib.net/">zlib</a> と <a href="http://www.libpng.org/pub/png/libpng.html">libpng</a> を使って、 Alchemy で PNG クラスを作ってみた。サンプルの一番下に該当。</p>
<p>PNG フォーマットには圧縮効率を上げるフィルタという仕組みがあって、フィルタの仕組み自体は PNG の仕様書みながら実装できるけど、どのフィルタを使うのが最適なのかはアプリケーションに任されてるけど正直んなとこまで突っ込みたくないしってことで、 Alcehmy 使えばフィルタ選択もしつつ高速化もできるかと思ったけどそんなに甘くなかった。
結果は見ての通り。OSEEEEEEEEEEEEEEEEE!!</p>
<p>ただ、フィルタの自動選択の方はコンボボックスで PNG_ALL_FILTERS を選択してエンコードすると libpng が各スキャンラインに対して自動的に最適であろうフィルタを選択してくれてる気がする。
あと、 AS では引数もなにもなしで <code>ByteArray.compress()</code> の一行で済まされてしまう zlib アルゴリズムでの圧縮に対して、 Alchemy で zlib を使うと圧縮レベルを 0(無圧縮)～9(最大圧縮) で設定することができる。当然圧縮率上げると遅いけど。
ちなみに libpng のデフォルトのフィルタタイプは PNG_ALL_FILTERS で、圧縮レベルは 6 ぽい。</p>
<p>速度重視なら <a href="http://ferv.jp/blog/2010/01/08/optimized-pngencoder-with-filters/">Optimized PNGEncoder with filters</a> 使って、ファイルサイズをある程度考慮しないとだったら Alchemy の PNG クラス使うとかそんな感じかなー・・・なんにせよ選択肢増えたってことでよしとするか・・・</p>
]]></content:encoded>
			<wfw:commentRss>http://ferv.jp/blog/2010/01/20/alchemy-png-encoder/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Optimized PNGEncoder with filters</title>
		<link>http://ferv.jp/blog/2010/01/08/optimized-pngencoder-with-filters/</link>
		<comments>http://ferv.jp/blog/2010/01/08/optimized-pngencoder-with-filters/#comments</comments>
		<pubDate>Thu, 07 Jan 2010 19:18:44 +0000</pubDate>
		<dc:creator>dsk</dc:creator>
				<category><![CDATA[Web]]></category>
		<category><![CDATA[ActionScript 3.0]]></category>
		<category><![CDATA[FileFormat]]></category>
		<category><![CDATA[PNGEncoder]]></category>

		<guid isPermaLink="false">http://ferv.jp/blog/?p=1126</guid>
		<description><![CDATA[PNG フォーマットには圧縮効率を上げるフィルタという仕組みがあるので、そいつを Optimized PNGEncoder に実装してみた。
PNG フォーマットで定義されてるフィルタの種類は5種類。

None  [...]]]></description>
			<content:encoded><![CDATA[<p>PNG フォーマットには圧縮効率を上げるフィルタという仕組みがあるので、そいつを <a href="http://ferv.jp/blog/2010/01/07/optimized-pngencoder/">Optimized PNGEncoder</a> に実装してみた。</p>
<p>PNG フォーマットで定義されてるフィルタの種類は5種類。</p>
<ul>
<li>None &#8211; 該当バイトをそのまま使用 (as3corelib の PNGEncoder はこれ一択)</li>
<li>Sub &#8211; 該当バイトと左のピクセルのバイトとの差分を使用</li>
<li>Up &#8211; 該当バイトと上のピクセルのバイトとの差分を使用</li>
<li>Average &#8211; 該当バイトと左/上のピクセルのバイトの平均値との差分を使用</li>
<li>Paeth &#8211; 該当バイトと左/上/左上のピクセルのバイトのうちの最近傍値との差分を使用</li>
</ul>
<p>ていう感じ。どのフィルタを使うのが圧縮率が高いかは対象の画像に依存する。</p>
<div style="text-align:center;width:465px;"><iframe title="Optimized PNGEncoder with filters - wonderfl build flash online" scrolling="no" src="http://wonderfl.net/blogparts/05c93e9a9bb9ec5e4eb2eeefb37cd26be36ebdd6" width="465" height="490" style="border:1px black solid;"></iframe><a href="http://wonderfl.net/code/05c93e9a9bb9ec5e4eb2eeefb37cd26be36ebdd6" title="Optimized PNGEncoder with filters - wonderfl build flash online">Optimized PNGEncoder with filters &#8211; wonderfl build flash online</a></div>
<p>ファイルサイズは 1 / 5 くらいになるけど、処理時間は倍以上かかっちゃう。このまま None 以外のフィルタ使うとサーバ資源は節約できるけどユーザのストレスは倍増間違いなし・・・ あ、Alchemy の出番ですね！！まだ Cygwin のセットアップも終わってないけど！！</p>
<p>// 関係ないけど Wonderfl でコードが 1000 行越えるとソースコードのプレビューのインデントとかカラーリングとかが壊れちゃいました。</p>]]></content:encoded>
			<wfw:commentRss>http://ferv.jp/blog/2010/01/08/optimized-pngencoder-with-filters/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Optimized PNGEncoder</title>
		<link>http://ferv.jp/blog/2010/01/07/optimized-pngencoder/</link>
		<comments>http://ferv.jp/blog/2010/01/07/optimized-pngencoder/#comments</comments>
		<pubDate>Wed, 06 Jan 2010 18:44:47 +0000</pubDate>
		<dc:creator>dsk</dc:creator>
				<category><![CDATA[Web]]></category>
		<category><![CDATA[ActionScript 3.0]]></category>
		<category><![CDATA[FileFormat]]></category>
		<category><![CDATA[PNGEncoder]]></category>

		<guid isPermaLink="false">http://ferv.jp/blog/?p=1111</guid>
		<description><![CDATA[Alchemy &#8211; asynchronous jpeg encodingで OptimizedJPGEncoder や AlchemyJPGEncoder の処理速度比較をみて、 PNGEncoder も多少 [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://segfaultlabs.com/devlogs/alchemy-asynchronous-jpeg-encoding">Alchemy &#8211; asynchronous jpeg encoding</a>で OptimizedJPGEncoder や AlchemyJPGEncoder の処理速度比較をみて、 PNGEncoder も多少最適化できるかなと思ったんでやってみた。<p>
<p>PNGフォーマットはJPGフォーマットのように複雑な変換処理がない単純なフォーマットなので、コード量が少く最適化箇所も少ない。ただ、複数回エンコードしたり、サイズの大きな BitmapData をエンコードする際にはメリットがでてくるんじゃなかろーかと。</p>
<div style="text-align:center;width:465px;"><iframe title="Optimized PNGEncoder - wonderfl build flash online" scrolling="no" src="http://wonderfl.net/blogparts/e6f61fe760d77ff75992173f5c346733b4ea08da" width="465" height="490" style="border:1px black solid;"></iframe><a href="http://wonderfl.net/code/e6f61fe760d77ff75992173f5c346733b4ea08da" title="Optimized PNGEncoder - wonderfl build flash online">Optimized PNGEncoder &#8211; wonderfl build flash online</a></div>
<p>処理速度比較の為に as3corelib の PNGEncoder と同じく PLTE チャンクは実装せず、フィルタオプションは &#8216;None&#8217; 一択で実装してる。 as3corelib にはない機能で、 BitmapData が不透明時の分岐を実装した。これをしとくことで BitmapData.transparent == false の BitmapData をエンコードした時にファイル容量が軽くなるはず。</p>
<p>最適化箇所をざっくり挙げとくと、 for 文の length をあらかじめ取得しとくとか、 for 文の中で何度も同結果の分岐を挟まないとか、 Vector を使うとかっていう最適化の基本的なところから、エンコード毎に使う PNG シグネチャ・ IEND チャンク・ CRC テーブルを定数にして使い回したりだとか、何度も同結果の null チェックしないとか、無駄な型変換をしないとかそんな感じ。<br />
サイズや透明・不透明によって違うけど、だいたい 25% くらい高速化してる気がする。</p>]]></content:encoded>
			<wfw:commentRss>http://ferv.jp/blog/2010/01/07/optimized-pngencoder/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
