質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

Q&A

解決済

1回答

4132閲覧

[Flutter]AlertDialogにFlatButtonを二つ入れたときにボタンの均等揃えができない。

namihana

総合スコア23

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

0グッド

0クリップ

投稿2020/04/04 16:40

現状イメージ画像のようになっているのですが、ダイアログ下部のflatbutton二つを左右にいい感じに離して表示したいのですがなかなかうまく行きません。
RowにcrossAxisAlignment: MainAxisAlignment.spaceBetween
やら色々試してみたのですが効果がないようで、何か良い方法を知っている方がいらっしゃれば教えていただけないでしょうか?

Gitより挙げております
https://github.com/nannantown/flutter_lang

イメージ説明

return AlertDialog( title: Text("コースのロックを解除する!コースのロックを解除する!"), actions: <Widget>[ // usually buttons at the bottom of the dialog Center( child: Row( children: <Widget>[ ButtonTheme( minWidth: 20.0, child: FlatButton( color: Colors.blueGrey, child: Text("CMを見る"), onPressed: () { unlockedList.unlock(widget.course.id); print(unlockedList.isUnlocked(widget.course.id)); Navigator.of(context).pop(); }, ), ), FlatButton( color: Colors.blueAccent, child: Text("500円でロックを一括解除"), onPressed: () { unlockedList.unlockAll(); Navigator.of(context).pop(); }, ), ], ), ), ], );

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

actions は標準的なボタンの配置しかサポートされていないようです。以下のようにすると、右寄せでボタンが配置されます。

return AlertDialog( title: Text("コースのロックを解除する!コースのロックを解除する!"), actions: <Widget>[ ButtonTheme( minWidth: 20.0, child: FlatButton( color: Colors.blueGrey, child: Text("CMを見る"), onPressed: () { unlockedList.unlock(widget.course.id); print(unlockedList.isUnlocked(widget.course.id)); Navigator.of(context).pop(); }, ), ), FlatButton( color: Colors.blueAccent, child: Text("500円でロックを一括解除"), onPressed: () { unlockedList.unlockAll(); Navigator.of(context).pop(); }, ), ], );

content を使えば、自分でボタンの配置についても指定できると思います。ただし、ボタンが横に並びきれなかった場合の考慮なども自分でやる必要が出てくるかもしれません。

return AlertDialog( title: Text("コースのロックを解除する!コースのロックを解除する!"), content: Row( mainAxisAlignment: MainAxisAlignment.spaceEvenly, children: <Widget>[ ButtonTheme( minWidth: 20.0, child: FlatButton( color: Colors.blueGrey, child: Text("CMを見る"), onPressed: () { unlockedList.unlock(widget.course.id); print(unlockedList.isUnlocked(widget.course.id)); Navigator.of(context).pop(); }, ), ), FlatButton( color: Colors.blueAccent, child: Text("500円でロックを一括解除"), onPressed: () { unlockedList.unlockAll(); Navigator.of(context).pop(); }, ), ], ), );

投稿2020/04/04 21:41

popobot

総合スコア6586

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

namihana

2020/04/05 14:48

いつもご回答ありがとうございます! 挙げていただいたコードで正常に動作しました。 全部contentに入れるということは試しておりませんでした。 元々Webの経験しかなかったもので、CSSのように全部操作できると考えがちになってしまうのですが、角プラットフォームの型のような物をもっと深く理解する必要がありそうですね。 勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問