android+读取文件内容少了n,从android中的资产读取epub文件时出现NullPoin...

我正在从资产文件夹访问epub文件以读取epub内容.我逐步遵循了siegmann.它在抛出nulpointer异常

Book book = (new EpubReader()).readEpub(epubInputStream);

我的代码段是

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();

System.err.println("assetManager>>"+assetManager);

try {

// find InputStream for book

InputStream epubInputStream = assetManager.open("ww.epub");

// Load Book from inputStream

Book book = (new EpubReader()).readEpub(epubInputStream);

// 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 tocReferences, int depth) {

if (tocReferences == null) {

return;

}

for (TOCReference tocReference : tocReferences) {

StringBuilder tocString = new StringBuilder();

for (int i = 0; i < depth; i++) {

tocString.append("");

}

tocString.append(tocReference.getTitle());

Log.i("epublib", tocString.toString());

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

}

}

}

ww.epub是我仅保存在资产文件夹中的文件.有人可以告诉我如何解决此nullpointer异常吗?

Logcat节目

02-04 13:22:57.189: W/System.err(22968): 1915 [main] ERROR nl.siegmann.epublib.epub.NCXDocument - null

02-04 13:22:57.189: W/System.err(22968): java.lang.NullPointerException

02-04 13:22:57.189: W/System.err(22968): at nl.siegmann.epublib.epub.NCXDocument.read(NCXDocument.java:92)

02-04 13:22:57.189: W/System.err(22968): at nl.siegmann.epublib.epub.EpubReader.processNcxResource(EpubReader.java:113)

02-04 13:22:57.189: W/System.err(22968): at nl.siegmann.epublib.epub.EpubReader.readEpub(EpubReader.java:99)

02-04 13:22:57.189: W/System.err(22968): at nl.siegmann.epublib.epub.EpubReader.readEpub(EpubReader.java:53)

02-04 13:22:57.189: W/System.err(22968): at nl.siegmann.epublib.epub.EpubReader.readEpub(EpubReader.java:37)

02-04 13:22:57.189: W/System.err(22968): at com.example.epub.MainActivity.onCreate(MainActivity.java:36)

02-04 13:22:57.189: W/System.err(22968): at android.app.Activity.performCreate(Activity.java:5104)

02-04 13:22:57.189: W/System.err(22968): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)

02-04 13:22:57.189: W/System.err(22968): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)

02-04 13:22:57.189: W/System.err(22968): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)

02-04 13:22:57.189: W/System.err(22968): at android.app.ActivityThread.access$600(ActivityThread.java:141)

02-04 13:22:57.189: W/System.err(22968): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)

02-04 13:22:57.189: W/System.err(22968): at android.os.Handler.dispatchMessage(Handler.java:99)

02-04 13:22:57.189: W/System.err(22968): at android.os.Looper.loop(Looper.java:137)

02-04 13:22:57.189: W/System.err(22968): at android.app.ActivityThread.main(ActivityThread.java:5039)

02-04 13:22:57.189: W/System.err(22968): at java.lang.reflect.Method.invokeNative(Native Method)

02-04 13:22:57.189: W/System.err(22968): at java.lang.reflect.Method.invoke(Method.java:511)

02-04 13:22:57.189: W/System.err(22968): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)

02-04 13:22:57.189: W/System.err(22968): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)

02-04 13:22:57.189: W/System.err(22968): at dalvik.system.NativeStart.main(Native Method)

02-04 13:22:57.189: I/epublib(22968): author(s): [Melville, Herman]

02-04 13:22:57.189: I/epublib(22968): title: Moby-Dick

02-04 13:22:57.189: D/AndroidRuntime(22968): Shutting down VM

02-04 13:22:57.189: W/dalvikvm(22968): threadid=1: thread exiting with uncaught exception (group=0x41e99930)

02-04 13:22:57.189: E/AndroidRuntime(22968): FATAL EXCEPTION: main

02-04 13:22:57.189: E/AndroidRuntime(22968): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.epub/com.example.epub.MainActivity}: java.lang.NullPointerException

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.ActivityThread.access$600(ActivityThread.java:141)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.os.Handler.dispatchMessage(Handler.java:99)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.os.Looper.loop(Looper.java:137)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.ActivityThread.main(ActivityThread.java:5039)

02-04 13:22:57.189: E/AndroidRuntime(22968): at java.lang.reflect.Method.invokeNative(Native Method)

02-04 13:22:57.189: E/AndroidRuntime(22968): at java.lang.reflect.Method.invoke(Method.java:511)

02-04 13:22:57.189: E/AndroidRuntime(22968): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)

02-04 13:22:57.189: E/AndroidRuntime(22968): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)

02-04 13:22:57.189: E/AndroidRuntime(22968): at dalvik.system.NativeStart.main(Native Method)

02-04 13:22:57.189: E/AndroidRuntime(22968): Caused by: java.lang.NullPointerException

02-04 13:22:57.189: E/AndroidRuntime(22968): at com.example.epub.MainActivity.onCreate(MainActivity.java:45)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.Activity.performCreate(Activity.java:5104)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)

02-04 13:22:57.189: E/AndroidRuntime(22968): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)

02-04 13:22:57.189: E/AndroidRuntime(22968): ... 11 more

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值