muzei のアート ソース (プラグイン) を作成しようとしています。
アプリは、私の場合はアプリのプライベート スペースのフォルダーである新しいアート ソースを提供することになっています。
ここの muzei API の例と、ここ で提供される詳細に 従って、アプリ用の 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>
muzei_wallpapers
res/xml フォルダーにxml ファイルを作成しました。
<?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)
ここ数日で立ち往生していて、ここで簡単なものが欠けているような気がします...