はじめに
ユーザーに任意の色を選択させたい場合に専用のUIをわざわざ作成するのは億劫です。そんなときに便利な使えそうなプラグインを見つけたので紹介します。
環境
- Flutter 1.22.6
- flutter_colorpicker 0.3.5
実装方法
プラグインの最新バージョンを確認
下記のサイトにアクセスし、バージョンを確認します。
data:image/s3,"s3://crabby-images/6b9fc/6b9fcadf049403038e48ce05212c8c98c64324c0" alt=""
flutter_colorpicker | Flutter package
HSV(HSB)/HSL/RGB/Material color picker inspired by all the good design for your amazing flutter apps.
記事作成の時点では0.3.5が最新バージョンでした。
data:image/s3,"s3://crabby-images/2885a/2885a47016996055b0dd32c437e17828118c43c5" alt=""
プラグインのインストール
pubspec.yamlのdependenciesに「flutter_colorpicker: ^0.3.5」を追記します。
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.0
flutter_colorpicker: ^0.3.5
その後、プロジェクト配下で「flutter pub get」コマンドを実行します。
よくわからない場合はAndroid Studioでpubspec.yamlファイルを開くと右上に「Pub get」ボタンがあるのでそれを押してください。
data:image/s3,"s3://crabby-images/497e3/497e3df4657caebd4246492fd71c9734ee0edd0e" alt=""
これでプラグインのインストールは完了です。
サンプルコード
import 'package:flutter/material.dart';
import 'package:flutter_colorpicker/flutter_colorpicker.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
Color selectedColor = Colors.blue;
Color pickerColor = Colors.blue;
void _changeColor(Color color) {
pickerColor = color;
}
void _showPicker(BuildContext context) {
showDialog(
context: context,
child: AlertDialog(
title: const Text('Pick a color!'),
content: SingleChildScrollView(
child: ColorPicker(
pickerColor: pickerColor,
onColorChanged: _changeColor,
showLabel: true,
pickerAreaHeightPercent: 0.8,
),
),
actions: <Widget>[
FlatButton(
child: const Text('Got it'),
onPressed: () {
setState(() => selectedColor = pickerColor);
Navigator.of(context).pop();
},
),
],
),
);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
backgroundColor: selectedColor,
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Text(
'You have pushed the button this many times:',
),
],
),
),
floatingActionButton: FloatingActionButton(
onPressed: () {
_showPicker(context);
},
child: Icon(Icons.color_lens),
),
);
}
}
実行結果
使い勝手な良さそうなカラーピッカーが無事表示されました。
data:image/s3,"s3://crabby-images/65a48/65a487a6c048e3750fe5da1c479631f3c76c764c" alt=""
その他のデザイン
さらにこのプラグインは上記のデザイン以外に色々なものがあります。
MaterialPicker
data:image/s3,"s3://crabby-images/6f468/6f4685e997c39c94c68f7fee3b2e9859a07cc09d" alt=""
BlockPicker
data:image/s3,"s3://crabby-images/c4a77/c4a777fadcb6c39a7ccb0cc09cb5f78011052155" alt=""
MultipleChoiceBlockPicker
BlockPickerの複数選択版などもあります。
data:image/s3,"s3://crabby-images/16482/164820bbddd17b53844449409ebc6312a33e90ed" alt=""
紹介した以外にもいくつかデザインやRGB選択じゃなく、HSV選択のピッカーもあるようです。
さいごに
今の所、色を選択するような機会はないんですが、無駄にリッチなので、どうにかして自作アプリで使えないかと考えています。
コメント