「Android/レイアウト/Layoutなどの使い方」の版間の差分
提供: 初心者エンジニアの簡易メモ
(→レイアウトをコードで実行) |
|||
行131: | 行131: | ||
ll.addView(text2); | ll.addView(text2); | ||
</pre> | </pre> | ||
+ | |||
+ | |||
+ | ===右下にボタン追加=== | ||
+ | |||
+ | int WC = ViewGroup.LayoutParams.WRAP_CONTENT; | ||
+ | int MP = ViewGroup.LayoutParams.MATCH_PARENT; | ||
+ | RelativeLayout btnLayout = new RelativeLayout(mContext); | ||
+ | btnLayout.setLayoutParams(new RelativeLayout.LayoutParams(MP, MP)); | ||
+ | RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(WC, WC); | ||
+ | lp.addRule(RelativeLayout.ALIGN_PARENT_RIGHT); | ||
+ | lp.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM); | ||
+ | Button button = new Button(this); | ||
+ | playButton.setText("play"); | ||
+ | btnLayout.addView(playButton, lp); | ||
+ | addView(btnLayout); | ||
+ | |||
+ | ===他レイアウトに↑の"右下ボタン"をかぶせる場合=== | ||
+ | FrameLayout frameLayout = new FrameLayout(this); | ||
+ | setContentView(frameLayout); | ||
+ | frameLayout.addView(otherLayout); | ||
+ | // 上の項目のコードをここへ入れる | ||
+ | - addView(btnLayout | ||
+ | + frameLayout.addView(btnLayout); // ここを切り替える | ||
+ | |||
+ | 後にaddViewしたものがz軸は手前表示となる | ||
+ | |||
+ | ===addViewをsetLayoutParams&addViewに分ける=== | ||
+ | RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(WC, WC); | ||
+ | btnLayout.addView(playButton, lp); | ||
+ | ↓ | ||
+ | RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(WC, WC); | ||
+ | playButton.setLayoutParams(lp); | ||
+ | btnLayout.addView(playButton); | ||
+ | 同じ意味になる | ||
==ConstraintLayout== | ==ConstraintLayout== |
2019年8月21日 (水) 16:04時点における版
目次
レイアウト種類
- LinearLayout ・・レイアウトを横に並べる
- FrameLayout ・・レイアウトを重ねる
- RelativeLayout ・・上の2つの組み合わせを同時にできる
水平一直線
<LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" >
垂直一直線
<LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" >
絶対位置を指定
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center_horizontal"
Linearでの配置
android:gravity="right" android:gravity=”bottom”
top コンテナの上部に配置 bottom コンテナの下部に配置 right コンテナの左側に配置 left コンテナの右側に配置 fill オブジェクトの高さ・幅を、コンテナのサイズに合わせる。 fill_vertical オブジェクトの高さをコンテナのサイズに合わせる。 fill_horizontal オブジェクトの幅をコンテナのサイズに合わせる。 center オブジェクトを中央に配置する。サイズ変更無し。 center_vertical オブジェクトを上下中央に配置しする。サイズ変更無し。 center_horizontal オブジェクトを左右中央に配置する。サイズ変更無し。 clip_vertical top/bottomの追加オプションとして、オブジェクトの上部/下部の境界をコンテナの境界に合わせます。 clip_horizontal left/rightの追加オプションとして、オブジェクトの左側/右側の境界をコンテナの境界に合わせま
す。
xmlレイアウトで分割
横に2分割
activity_main.xml
<LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/ll" android:orientation="horizontal"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="1111" android:layout_weight="1" /> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="2222" android:layout_weight="1" /> </LinearLayout>
縦に2分割
activity_main.xml
<LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/ll" android:orientation="vertical"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="1111" android:layout_weight="1" /> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="2222" android:layout_weight="1" /> </LinearLayout>
レイアウトをコードで実行
activity_main.xml
<LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/ll" android:orientation="vertical">
横に2分割
MainActivity.java
LinearLayout ll = findViewById(R.id.ll); ll.setOrientation(LinearLayout.HORIZONTAL); TextView text = new TextView(getApplicationContext()); text.setText("1111"); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT); params.weight = 1.0f; text.setLayoutParams(params); ll.addView(text); TextView text2 = new TextView(getApplicationContext()); text2.setText("2222"); text2.setLayoutParams(params); ll.addView(text2);
縦に2分割
MainActivity.java
LinearLayout ll = findViewById(R.id.ll); ll.setOrientation(LinearLayout.VERTICAL); TextView text = new TextView(getApplicationContext()); text.setText("1111"); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT); params.weight = 1.0f; text.setLayoutParams(params); ll.addView(text); TextView text2 = new TextView(getApplicationContext()); text2.setText("2222"); text2.setLayoutParams(params); ll.addView(text2);
右下にボタン追加
int WC = ViewGroup.LayoutParams.WRAP_CONTENT; int MP = ViewGroup.LayoutParams.MATCH_PARENT; RelativeLayout btnLayout = new RelativeLayout(mContext); btnLayout.setLayoutParams(new RelativeLayout.LayoutParams(MP, MP)); RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(WC, WC); lp.addRule(RelativeLayout.ALIGN_PARENT_RIGHT); lp.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM); Button button = new Button(this); playButton.setText("play"); btnLayout.addView(playButton, lp); addView(btnLayout);
他レイアウトに↑の"右下ボタン"をかぶせる場合
FrameLayout frameLayout = new FrameLayout(this); setContentView(frameLayout); frameLayout.addView(otherLayout); // 上の項目のコードをここへ入れる - addView(btnLayout + frameLayout.addView(btnLayout); // ここを切り替える
後にaddViewしたものがz軸は手前表示となる
addViewをsetLayoutParams&addViewに分ける
RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(WC, WC); btnLayout.addView(playButton, lp);
↓
RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(WC, WC); playButton.setLayoutParams(lp); btnLayout.addView(playButton);
同じ意味になる
ConstraintLayout
Android Studio 2.2 previewよりConstraintLayoutが追加された
https://qiita.com/tomoima525/items/0584be581a0d3a4db8c5
参考
右上とか左下とか9分割とかの参考ページ