WX310SA と tDiary 絵日記プラグイン機能追加版
この間書いた対処方法は、やっぱりあまりに手抜きなやり方だったらしく、結局正しいサイズが取れていなかったことが分かりました。乗りかかった船なのでちょっと調べてみたんですが、そもそも image_size.rb での JPEG ファイルのサイズ取得方法がどうも不十分っぽい。libjpeg での処理と見比べたりといろいろ調べ始めたときに、はた、と気がつきました。
僕は tDiary の絵日記プラグイン機能追加版を ImageMagick の「convert」を使うモードで使っています。だとすれば、サイズ取得にも同じ ImageMagick に含まれる「identify」を使えばいいのです。WX310SA の JPEG ファイルでも、identify コマンドでは正しいサイズが取得できることはかなり最初の方から分かっていました。
というわけで、おととい加えた image_size.rb への修正は元に戻し、代わりに絵日記プラグイン機能追加版のスクリプト、image_ex.rb に下記のような修正を加えました。
kazawa@tpx20:~/src/tdiary/plugin$ diff -u image_ex.rb.orig image_ex.rb
--- image_ex.rb.orig 2006-03-21 22:13:06.761265514 +0900
+++ image_ex.rb 2006-03-21 22:21:13.690420236 +0900
@@ -139,7 +139,7 @@
end
def image_link( id, str )
- @image_date ||= @date.strftime("%Y%m%d")
+ @image_date ||= @date.strftime("%Y%m%d")
@image_year ||= @date.strftime("%Y")
if @imageex_yearlydir == 1
image_url = %Q[#{@image_url}/#{@image_year}/]
@@ -178,7 +178,7 @@
imageex_convertedwidth = @options && @options['image_ex.convertedwidth'] || 160
imageex_convertedheight = @options && @options['image_ex.convertedheight'] || 120
- if imageex_useresize == 1 || imageex_useresize ==2
+ if imageex_useresize == 2
begin
require 'image_size.rb'
rescue LoadError
@@ -198,7 +198,7 @@
imageex_convertedsize = %Q[#{imageex_convertedheight}x#{imageex_convertedwidth}]
imageex_convertedsize
end
- system(imageex_convertpath , "-geometry", imageex_convertedsize , orig, new)
+ system(imageex_convertpath , "-quality", "100", "-geometry", imageex_convertedsize , orig, new)
if FileTest::size?( new ) == 0
File::delete( new )
end
@@ -268,7 +268,26 @@
}
end
- if imageex_useresize == 1 or imageex_useresize == 2
+ if imageex_useresize == 1
+ open("|identify #{image_file}", "rb") do |fh|
+ img_info = fh.readline
+ img_info =~ /^\S+\s+(\S+)\s+(\d+)x(\d+)\s+/m
+ orig_type = $1
+ width = $2.to_i
+ height = $3.to_i
+ if imageex_converttype == 0
+ new_type = "jpg"
+ elsif imageex_converttype == 1
+ new_type = "png"
+ end
+ if width
+ if width > imageex_thresholdsize or height > imageex_thresholdsize
+ small_image_file = %Q[#{image_dir}s#{image_date}_#{image_name.length.to_s}.#{new_type}]
+ resize_image(image_file, small_image_file, width, height, imageex_convertedwidth, imageex_convertedheight, orig_type, new_type)
+ end
+ end
+ end
+ elsif imageex_useresize == 2
open(image_file,"rb") do |fh|
img = ImageSize.new(fh.read)
width = img.get_width
今度こそちゃんと動くようになったと思うんだけど、どうだろう? (いくつか本題とは関係ない修正も加わっているのはご愛嬌)
ちなみに右の写真は、今日の自分の誕生日用のガトーショコラ作りをお手伝いする鳥乃さんです。