はじめに
Flutterでアプリを開発をしている時に便利なのがプラグイン。
簡単に導入できますし、豊富な機能が公開されています。
ただし、ときどき不具合や自分の思い通りにならない機能等がありプラグインを自分好みにカスタマイズしたいと思う時があると思います。
そんな今回は外部プラグインをカスタマイズする方法を紹介しようと思います。
環境
- Flutter 2.2.3
カスタマイズまでの準備
今回は「webview_flutter」をカスタマイズしていきたいと思います。
「webview_flutter」はflutter.devの公式のプラグインなため、オリジナルのソースコードの場所が少しだけ複雑です。
ソースコードの入手
まずはwebview_flutterのソースコードを手に入れるため、下記のサイトに行きます。
data:image/s3,"s3://crabby-images/6b9fc/6b9fcadf049403038e48ce05212c8c98c64324c0" alt=""
pub.devサイトに行ったら、「Repository(GitHub)」をクリックしGitHubへ遷移します。
data:image/s3,"s3://crabby-images/4743e/4743e56fde26491a5ec964063c9f9a1a4294b214" alt=""
次に「Code」を押し、pluginsのトップ画面へ遷移します。
data:image/s3,"s3://crabby-images/ca124/ca124720ed2089c68f45dccb585f78a22283f7df" alt=""
次に「Releases」を押して、正式リリースされているプラグインの一覧画面へ遷移します。
data:image/s3,"s3://crabby-images/d5399/d5399588e10244faa7ecd8848beef1b30d692929" alt=""
そこでwebview_flutterでカスタマイズしたバージョンのソースコードをzipまたはtar.gzでダウンロードします。
今回はzipファイルで説明します。
data:image/s3,"s3://crabby-images/f5afb/f5afbcf1f8985b7debd3acd733d8f36219000b31" alt=""
次にFlutterのプロジェクトのルートフォルダに「plugins」というフォルダを作成します。
data:image/s3,"s3://crabby-images/44180/44180dde7c5b164d015fe0a045284f367ac01039" alt=""
そのpluginsフォルダに上記のGitHubでダウンロードした「plugins-webview_flutter-v2.0.10.zip」を展開した中にある「webview_flutter」をこのpluginsフォルダにコピーします。
data:image/s3,"s3://crabby-images/d5dcd/d5dcdb998ccee65936a866dd52a81f6434b1b5ad" alt=""
data:image/s3,"s3://crabby-images/8944f/8944f7a2492b2886049694793b29d6f5ade8257f" alt=""
これでソースコードの入手作業は完了です。
入手したソースコードをプロジェクトに認識させる
Android Studioを開きpubspec.yamlを下記のように編集します。
dependencies:
flutter:
sdk: flutter
# The following adds the Cupertino Icons font to your application.
# Use with the CupertinoIcons class for iOS style icons.
cupertino_icons: ^1.0.2
webview_flutter:
path: ./plugins/webview_flutter
dev_dependencies:
通常の場合は「webview_flutter: any」等書きますが、今回はプロジェクト配下のソースコードをプラグインと認識させるためにプラグインのフォルダへのパスを記述します。
記述したら、プロジェクト配下で「flutter pub get」コマンドを実行
よくわからない場合はAndroid Studioでpubspec.yamlファイルを開くと右上に「Pub get」ボタンがあるのでそれを押して下さい。
data:image/s3,"s3://crabby-images/05c74/05c74a9a0deca3bf98e313b412d928e238da5e2b" alt=""-1024x576.png)
するとpluginsフォルダにある「webview_flutter」が…
data:image/s3,"s3://crabby-images/ce212/ce2127dd2601ecbeaf776d19343acb04e877576d" alt=""
「Library root」と認識してwebivew_flutterが使えるようになります。
data:image/s3,"s3://crabby-images/77f42/77f42adf994360a30f8464e74d25fca09b14d7dd" alt=""
あとはカスマイズするだけ!
あとはplugins/webview_flutterのソースコードを自分好みにいじくるだけです。
注意点
既に「webview_flutter」を入れていてカスタマイズのプラグインに切り替えた場合に、うまくAndroid Studioが認識してくれていない時があります。その際は「flutter pub get」後にAndroid Studioを再起動させてみてください。
さいごに
意外とやり方が簡単だった。
コメント