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]的主要内容,如果未能解决你的问题,请参考以下文章

Muzei 插件卡在永远不会收到 onUpdate() 调用的状态

Muzei 源选择器中的图标似乎无法正确缩放

获取“致命异常 AsyncTask #1”

获取 Android 运行时:致命异常

片段中的Android致命异常

致命异常主要android