環境
Windows10 64bit
Ruby 2.1.6p336
状況
ruby
1require 'zbar' 2 3ZBar::Image.from_jpeg(File.read('test.jpg')).process
が実行できず、
C:/Ruby21-x64/lib/ruby/gems/2.1.0/gems/zbar-0.2.2/lib/zbar/lib.rb:12:in `rescue in <module:ZBar>': Didn't find libzbar on your system (LoadError) Please install zbar (http://zbar.sourceforge.net/) or set ZBAR_LIB if it's in a weird place FFI::Library::ffi_lib() failed with error: Could not open library 'C:\Program Files (x86)\ZBar\bin\libzbar-0.dll': from C:/Ruby21-x64/lib/ruby/gems/2.1.0/gems/zbar-0.2.2/lib/zbar/lib.rb:9:in `<module:ZBar>' from C:/Ruby21-x64/lib/ruby/gems/2.1.0/gems/zbar-0.2.2/lib/zbar/lib.rb:1:in `<top (required)>' from C:/Ruby21-x64/lib/ruby/site_ruby/2.1.0/rubygems/core_ext/kernel_require.rb:55:in `require' from C:/Ruby21-x64/lib/ruby/site_ruby/2.1.0/rubygems/core_ext/kernel_require.rb:55:in `require' from C:/Ruby21-x64/lib/ruby/gems/2.1.0/gems/zbar-0.2.2/lib/zbar.rb:3:in `<top (required)>' from C:/Ruby21-x64/lib/ruby/site_ruby/2.1.0/rubygems/core_ext/kernel_require.rb:133:in `require' from C:/Ruby21-x64/lib/ruby/site_ruby/2.1.0/rubygems/core_ext/kernel_require.rb:133:in `rescue in require' from C:/Ruby21-x64/lib/ruby/site_ruby/2.1.0/rubygems/core_ext/kernel_require.rb:40:in `require' from hoge.rb:1:in `<main>'
と出る。
経緯
まず、gem 'zbar' とGemfileに書き込み、zbarをインストールした。次に、zbarのWindows版インストーラ、zbar-0.10-setup.exeを使い、C:\Program Files (x86)\ZBarへインストールをした。そして、ZBAR_LIBという環境変数を作った。中身はC:\Program Files (x86)\ZBar\bin\libzbar-0.dllである。
行った検証
上記のような手順でインストールを行いパスを通しました。しかし、うまく読み込めません。
自分なりにいろいろ調べてみたところ、ZBAR_LIBは読み込めていました。また、FFIというライブラリの中の、FFI::DynamicLibrary.open()という関数の部分で失敗しているところまではわかりました。しかし、なぜ失敗しているのかがサッパリわかりません。
ZBarのインストールには成功しており、FFIはCのライブラリをRubyから呼び出すためのライブラリらしいので、パス関係がうまくいってないのではないかと推測しています。どのようにしたらうまく動いてくれるのでしょうか?
あなたの回答
tips
プレビュー