スタッフブログ

STAFF BLOG

アプリ開発日誌

2020.08.24

[Flutter]ColumnとRowの方向がごっちゃになるので整理してみた

こんにちは、ヒナです。
今回、FlutterのColumnとRowについて紹介します。

Column

Column Widgetを使うことで、Widgetを縦に並べることができます。

縦に並べる

縦にWidgetを並べるときは、Column Widgetを使い、children に並べたいWidget一覧を指定します。

Column(
    children: [
        Text('1列目'),
        Text('2列目'),
        Text('3列目'),
    ],
)

列の中央寄せ・下寄せ・均等配置

縦に並べるWidgetの配置を変えるときは、 mainAxisAlignment を指定します。

Column(
  mainAxisAlignment: MainAxisAlignment.center,
  children: <Widget>[],
)

基本位置調整一覧
中央寄せ:mainAxisAlignment.center
下寄せ :mainAxisAlignment.end
均等配置:mainAxisAlignment. spaceEvenly

左寄せ・右寄せ

縦に並べたWidgetの横方向の配置を変えるときは、 crossAxisAlignment を指定します。

Column(
  crossAxisAlignment: CrossAxisAlignment.start,
  children: <Widget>[],
)

基本位置調整一覧
左寄せ:CrossAxisAlignment.start
右寄せ:CrossAxisAlignment.end

Row

Row Widgetを使うことで、Widgetを横に並べることができます。

横に並べる

横にWidgetを並べるときは、Row Widgetを使い、children に並べたいWidget一覧を指定します。

Row(
  children: <Widget>[
    Text('1行目'),
    Text('2行目'),
    Text('3行目'),
  ],
)

中央寄せ・右寄せ・均等配置

横に並べるWidgetの配置を変えるときは、 mainAxisAlignment を指定します。

Row(
  mainAxisAlignment: MainAxisAlignment.center,
  children: <Widget>[],
)

基本位置調整一覧
中央寄せ:MainAxisAlignment.center
右寄せ :MainAxisAlignment.end
均等配置:MainAxisAlignment.spaceEvenly

上寄せ・下寄せ

横に並べたWidgetの縦方向の配置を変えるときは、 crossAxisAlignment を指定します。

Row(
  crossAxisAlignment: CrossAxisAlignment.start,
  children: <Widget>[],
)

基本位置調整一覧
上寄せ:CrossAxisAlignment.start
下寄せ:CrossAxisAlignment.end

まとめ

縦に並べるときは Column Widget、横に並べるときは Row Widgetを使います。
ColumnかRowかによってmainAxisAlignmentとcrossAxisAlignmentの位置調整の方向が変わるので、
注意してください。

私は、ColumnとRowの方向がごっちゃになることが多いので、
Column、Rowが伸びる方向をmainとして、それと直角に交わる方向をcrossとして
位置調整していると覚えています。

ライタープロフィール

【N】
Webエンジニアの経験を経て、アプリエンジニアとしてEDAに入社。
Flutter開発導入のファシリテーターとして、勉強会などを担当している。

BACK

お問合せ

イーディーエーに興味をお持ちいただいて
ありがとうございます!
スマホアプリに関するご相談、
お見積りや弊社へのご質問など、
お気軽にお問い合わせください。
担当者より折り返しご連絡させていただきます。

    お名前必須
    会社名
    メールアドレス必須
    電話番号必須
    お問合わせ種別必須
    お問合わせ内容必須

    アンケートにご協力ください。
    弊社サイトへはどのようにしてアクセスされましたか?

    個人情報のお取扱いに関する同意事項

    1.事業者の氏名又は名称

    株式会社イーディーエー

    2.個人情報保護管理者の氏名又は職名、所属及び連絡先

    個人情報保護管理者 小宮 保人
    Mail:[email protected]

    3.取得した個人情報の利用目的

    当フォームで取得した個人情報は、お問い合わせに関する回答のために利用し、目的外利用はいたしません。

    4.弊社が取得した個人情報の第三者への委託、提供について

    弊社は、ご本人に関する情報をご本人の同意なしに第三者に委託または提供することはありません。

    5.個人情報保護のための安全管理

    弊社は、ご本人の個人情報を保護するための規程類を定め、従業者全員に周知・徹底と啓発・教育を図るとともに、その遵守状況の監査を定期的に実施いたします。
    また、ご本人の個人情報を保護するために必要な安全管理措置の維持・向上に努めてまいります。

    6.個人情報の開示・訂正・利用停止等の手続

    ご本人が、弊社が保有するご自身の個人情報の、利用目的の通知、開示、内容の訂正、追加又は削除、利用の停止、消去及び第三者への提供の停止を求める場合には、下記に連絡を頂くことで、対応致します。

    株式会社イーディーエー 個人情報お問合せ窓口
    〒106-0032 東京都港区六本木7丁目14番23 ラウンドクロス六本木4F
    TEL:03-5422-7524 FAX:03-5422-7534
    Mail:[email protected]

    7.ご提供いただく情報の任意性

    個人情報のご提供は任意ですが、同意を頂けない場合には、第3項にあります利用目的が達成できない事をご了承いただくこととなります。

    8.弊社Webサイトの運営について

    弊社サイトでは、ご本人が弊社Webサイトを再度訪問されたときなどに、より便利に閲覧して頂けるよう「クッキー(Cookie)」という技術を使用することがあります。これは、ご本人のコンピュータが弊社Webサイトのどのページに訪れたかを記録しますが、ご本人が弊社Webサイトにおいてご自身の個人情報を入力されない限りご本人ご自身を特定、識別することはできません。
    クッキーの使用を希望されない場合は、ご本人のブラウザの設定を変更することにより、クッキーの使用を拒否することができます。その場合、一部または全部のサービスがご利用できなくなることがあります。