컨텐츠를 선형 레이아웃 안에 중앙에 배치하는 방법은 무엇입니까?
저는 중심을 잡으려고 노력하고 있습니다.ImageView
내부에LinearLayout
가로, 세로로 할 수가 없어요.사용하지 않는 주된 이유는RelativeLayout
그것은 내가 필요하기 때문입니다.layout_weight
(나의Activity
동일하게 분할되어야 하고 또한 서로 다른 화면 폭에 대응해야 하는 네 개의 열로 구성되어 있으며, 각 열은 하나의 열을 가지고 있습니다.ImageView
중심 및 비확장).
지금까지 제 xml은 다음과 같습니다.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000"
android:baselineAligned="false"
android:gravity="center"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".Main" >
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1" >
<ImageView
android:id="@+id/imageButton_speak"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/image_bg"
android:src="@drawable/ic_speak" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1" >
<ImageView
android:id="@+id/imageButton_readtext"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/image_bg"
android:src="@drawable/ic_readtext" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1" >
<ImageView
android:id="@+id/imageButton_edit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/image_bg"
android:src="@drawable/ic_edit" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1" >
<ImageView
android:id="@+id/imageButton_config"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/image_bg"
android:src="@drawable/ic_config" />
</LinearLayout>
</LinearLayout>
android:gravity
아이들의 정렬을 처리합니다.
android:layout_gravity
자체 정렬을 처리합니다.
이것들 중 하나를 사용합니다.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000"
android:baselineAligned="false"
android:gravity="center"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".Main" >
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center" >
<ImageView
android:id="@+id/imageButton_speak"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/image_bg"
android:src="@drawable/ic_speak" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center" >
<ImageView
android:id="@+id/imageButton_readtext"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/image_bg"
android:src="@drawable/ic_readtext" />
</LinearLayout>
...
</LinearLayout>
(리프 노드를 제외한 모든 노드는 다음을 수행해야 합니다.android:gravity="center"
.)
또는
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000"
android:baselineAligned="false"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".Main" >
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1" >
<ImageView
android:id="@+id/imageButton_speak"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:background="@drawable/image_bg"
android:src="@drawable/ic_speak" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_weight="1" >
<ImageView
android:id="@+id/imageButton_readtext"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:background="@drawable/image_bg"
android:src="@drawable/ic_readtext" />
</LinearLayout>
...
</LinearLayout>
(루트 노드를 제외한 모든 노드에는android:layout_gravity="center"
.)
android:layout_gravity
레이아웃 자체에 사용됩니다.
사용하다android:gravity="center"
자녀를 위한LinearLayout
따라서 코드는 다음과 같아야 합니다.
<LinearLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:layout_weight="1" >
저는 여기에 언급된 해결책을 시도했지만 도움이 되지 않았습니다.나는 그 해결책이layout_width
을 사용해야 합니다.wrap_content
가치로서
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:layout_weight="1" >
여기 샘플 코드가 있습니다.이것은 저에게 효과가 있었습니다.
<LinearLayout
android:gravity="center"
>
<TextView
android:layout_gravity="center"
/>
<Button
android:layout_gravity="center"
/>
</LinearLayout>
따라서 모든 내용(텍스트 보기 및 단추)을 중앙에 배치하도록 선형 레이아웃을 설계한 다음 텍스트 보기 및 단추를 선형 레이아웃의 중앙에 상대적으로 배치합니다.
android:gravity
레이아웃에서 자식을 정렬하는 데 사용할 수 있습니다.
android:layout_gravity
모든 뷰에서 부모에 정렬하는 데 사용할 수 있습니다.
참고: 자가 또는 어린이가 예상대로 중심을 잡지 못하는 경우 폭/높이가
match_parent
그리고 다른 것으로 바꿉니다.
만약 당신이 자바 코드로 답을 찾고 있다면,
LinearLayout linearLayout = new LinearLayout(context);
linearLayout.setGravity(Gravity.CENTER);
// add children
언급URL : https://stackoverflow.com/questions/18051472/how-to-center-the-content-inside-a-linear-layout
'programing' 카테고리의 다른 글
SQLiteOpenHelper onCreate() / onUpgrade()는 언제 실행됩니까? (0) | 2023.08.05 |
---|---|
언제 os.name , sys.platform 또는 platform.system을 사용해야 합니까? (0) | 2023.08.05 |
모바일 장치에서 jQuery UI 슬라이더 터치 & 드래그/드롭 지원 (0) | 2023.08.05 |
Node.js에서 마이크로타임을 얻는 방법은 무엇입니까? (0) | 2023.08.05 |
이전 활동으로 돌아가는 것을 방지하는 방법은 무엇입니까? (0) | 2023.08.05 |