在android中运行epub文件时出错

时间:2013-02-01 04:58:27

标签: android epub3

我想在android中构建并运行epub内容并引用http://www.siegmann.nl/epublib/android并尝试实现相同但我得到的错误如

02-01 10:08:15.726: D/dalvikvm(27839): Late-enabling CheckJNI
02-01 10:08:15.926: I/dalvikvm(27839): Could not find method org.slf4j.LoggerFactory.getLogger, referenced from method nl.siegmann.epublib.epub.EpubReader.<clinit>
02-01 10:08:15.926: W/dalvikvm(27839): VFY: unable to resolve static method 4251: Lorg/slf4j/LoggerFactory;.getLogger (Ljava/lang/Class;)Lorg/slf4j/Logger;
02-01 10:08:15.926: D/dalvikvm(27839): VFY: replacing opcode 0x71 at 0x0002
02-01 10:08:16.066: I/dalvikvm(27839): Could not find method org.slf4j.Logger.error, referenced from method nl.siegmann.epublib.epub.EpubReader.getPackageResourceHref
02-01 10:08:16.066: W/dalvikvm(27839): VFY: unable to resolve interface method 4249: Lorg/slf4j/Logger;.error (Ljava/lang/String;Ljava/lang/Throwable;)V
02-01 10:08:16.066: D/dalvikvm(27839): VFY: replacing opcode 0x72 at 0x0045
02-01 10:08:16.066: I/dalvikvm(27839): Could not find method org.slf4j.Logger.error, referenced from method nl.siegmann.epublib.epub.EpubReader.processPackageResource
02-01 10:08:16.066: W/dalvikvm(27839): VFY: unable to resolve interface method 4249: Lorg/slf4j/Logger;.error (Ljava/lang/String;Ljava/lang/Throwable;)V
02-01 10:08:16.066: D/dalvikvm(27839): VFY: replacing opcode 0x72 at 0x000f
02-01 10:08:16.066: W/dalvikvm(27839): Exception Ljava/lang/NoClassDefFoundError; thrown while initializing Lnl/siegmann/epublib/epub/EpubReader;
02-01 10:08:16.066: D/AndroidRuntime(27839): Shutting down VM
02-01 10:08:16.066: W/dalvikvm(27839): threadid=1: thread exiting with uncaught exception (group=0x41e99930)
02-01 10:08:16.066: E/AndroidRuntime(27839): FATAL EXCEPTION: main
02-01 10:08:16.066: E/AndroidRuntime(27839): java.lang.ExceptionInInitializerError
02-01 10:08:16.066: E/AndroidRuntime(27839):    at com.example.epub2.MainActivity.onCreate(MainActivity.java:32)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.Activity.performCreate(Activity.java:5104)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.ActivityThread.access$600(ActivityThread.java:141)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.os.Handler.dispatchMessage(Handler.java:99)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.os.Looper.loop(Looper.java:137)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at android.app.ActivityThread.main(ActivityThread.java:5039)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at java.lang.reflect.Method.invokeNative(Native Method)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at java.lang.reflect.Method.invoke(Method.java:511)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
02-01 10:08:16.066: E/AndroidRuntime(27839):    at dalvik.system.NativeStart.main(Native Method)
02-01 10:08:16.066: E/AndroidRuntime(27839): Caused by: java.lang.NoClassDefFoundError: org.slf4j.LoggerFactory
02-01 10:08:16.066: E/AndroidRuntime(27839):    at nl.siegmann.epublib.epub.EpubReader.<clinit>(EpubReader.java:33)

我的代码是::

 public class MainActivity extends Activity { 

/** Called when the activity is first created. */
@Override 
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setContentView(R.layout.activity_main);
    AssetManager assetManager = getAssets();
    try { 
      // find InputStream for book
      InputStream is = getAssets().open("ww.epub");
      Book book = new EpubReader().readEpub(is);
      // Load Book from inputStream


      // Log the book's authors
      Log.i("epublib", "author(s): " + book.getMetadata().getAuthors());

      // Log the book's title
      Log.i("epublib", "title: " + book.getTitle());

      // Log the book's coverimage property
      Bitmap coverImage = BitmapFactory.decodeStream(book.getCoverImage()
          .getInputStream());
      Log.i("epublib", "Coverimage is " + coverImage.getWidth() + " by "
          + coverImage.getHeight() + " pixels");

      // Log the tale of contents
      logTableOfContents(book.getTableOfContents().getTocReferences(), 0);
    } catch (IOException e) {
      Log.e("epublib", e.getMessage());
    }
}
private void logTableOfContents(List<TOCReference> tocReferences, int depth) {
    if (tocReferences == null) {
      return;
    }
    for (TOCReference tocReference : tocReferences) {
      StringBuilder tocString = new StringBuilder();
      for (int i = 0; i < depth; i++) {
        tocString.append("\t");
      }
      tocString.append(tocReference.getTitle());
      Log.i("epublib", tocString.toString());

      logTableOfContents(tocReference.getChildren(), depth + 1);
    }
  }
}

是的,我提到了两个jar库,因为他们提到了!我没有找到解决方案,任何人都可以帮助我吗?

1 个答案:

答案 0 :(得分:3)

02-01 10:08:15.926: I/dalvikvm(27839): Could not find method org.slf4j.LoggerFactory.getLogger, referenced from method nl.siegmann.epublib.epub.EpubReader.<clinit> 

此错误表明您的包未加载jar文件。您必须在libs文件夹中添加两个jar文件并将它们附加到构建路径