muzei - 致命异常:IntentService [TaskQueueService]
Posted
技术标签:
【中文标题】muzei - 致命异常:IntentService [TaskQueueService]【英文标题】:muzei - FATAL EXCEPTION: IntentService[TaskQueueService] 【发布时间】:2014-07-17 01:57:27 【问题描述】:我正在尝试为 muzei 创建一个艺术源(插件)。
该应用程序应该提供一个新的艺术源,在我的例子中是我的应用程序私有空间的一个文件夹。
按照 muzei api here 中的示例以及它提供的详细信息 here 我为我的应用创建了一个 FileProvider。
我已将此代码添加到我的清单中:
<provider
android:name="android.support.v4.content.FileProvider"
android:authorities="com.foo.bar.fileprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/muzei_wallpapers" />
</provider>
我在我的 res/xml 文件夹中创建了 xml 文件 muzei_wallpapers
:
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<files-path name="my_images" path="files/" />
</paths>
如您所见,它指向我的files/
文件夹。
最后是我的扩展MuzeiArtSource
的课程:
public class MuzeiService extends MuzeiArtSource
Uri imgUri;
public MuzeiService()
super(MuzeiService.class.getName());
@Override
public void onCreate()
super.onCreate();
// setUserCommands(BUILTIN_COMMAND_ID_NEXT_ARTWORK); // manual switch image
@Override
protected void onUpdate(int arg0)
imgUri = muzeiContentUri();
publishArtwork(new Artwork.Builder()
.imageUri( Uri.parse("imgUri") )
.title("Example image")
.byline("Unknown person, c. 1980")
.build());
public Uri muzeiContentUri()
File imagePath = new File(getFilesDir(), "files");
File newFile = new File(imagePath, "wallpaper0.png");
Uri contentUri = FileProvider.getUriForFile(getApplicationContext(), "com.foo.bar.fileprovider", newFile);
return contentUri;
在我看来这是最简单的例子,我可以返回一个简单文件(名为 wallpapaper0)的 uri
当我为我的应用程序选择 muzei 作为资源时,我得到一个“不幸的是 muzei 已停止”,并且 logcat 是:
05-28 04:29:40.350: E/AndroidRuntime(3670): FATAL EXCEPTION: IntentService[TaskQueueService]
05-28 04:29:40.350: E/AndroidRuntime(3670): java.lang.NullPointerException
05-28 04:29:40.350: E/AndroidRuntime(3670): at com.google.android.apps.muzei.util.IOUtil.readFullyWriteToOutputStream(IOUtil.java:210)
05-28 04:29:40.350: E/AndroidRuntime(3670): at com.google.android.apps.muzei.util.IOUtil.readFullyWriteToFile(IOUtil.java:202)
05-28 04:29:40.350: E/AndroidRuntime(3670): at com.google.android.apps.muzei.ArtworkCache.maybeDownloadCurrentArtworkSync(ArtworkCache.java:122)
05-28 04:29:40.350: E/AndroidRuntime(3670): at com.google.android.apps.muzei.TaskQueueService.onHandleIntent(TaskQueueService.java:56)
05-28 04:29:40.350: E/AndroidRuntime(3670): at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:65)
05-28 04:29:40.350: E/AndroidRuntime(3670): at android.os.Handler.dispatchMessage(Handler.java:99)
05-28 04:29:40.350: E/AndroidRuntime(3670): at android.os.Looper.loop(Looper.java:137)
05-28 04:29:40.350: E/AndroidRuntime(3670): at android.os.HandlerThread.run(HandlerThread.java:61)
我真的很感激任何帮助,因为我最近几天一直坚持下去,我觉得我在这里遗漏了一些简单的东西......
【问题讨论】:
【参考方案1】:你正在传递Uri.parse("imgUri")
- 你应该只是传递imgUri
:
imgUri = muzeiContentUri();
publishArtwork(new Artwork.Builder()
.imageUri(imgUri)
.title("Example image")
.byline("Unknown person, c. 1980")
.build());
【讨论】:
如果我改变这个我得到:The method parse(String) in the type Uri is not applicable for the arguments (Uri)
您确实看过我发布的代码对吗?你已经创建了一个 Uri,所以你不需要做任何解析。以上是关于muzei - 致命异常:IntentService [TaskQueueService]的主要内容,如果未能解决你的问题,请参考以下文章