Computer >> 컴퓨터 >  >> 프로그램 작성 >> Android

Android에서 GridLayout을 화면 크기에 맞추는 방법은 무엇입니까?


이 예는 Android에서 GridLayout을 화면 크기에 맞추는 방법을 보여줍니다.

1단계 − Android Studio에서 새 프로젝트를 생성하고 파일 ⇒ 새 프로젝트로 이동하여 필요한 모든 세부 정보를 입력하여 새 프로젝트를 생성합니다.

2단계 − res/layout/activity_main.xml에 다음 코드를 추가합니다.

<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="https://schemas.android.com/apk/res/android"
   xmlns:app="https://schemas.android.com/apk/res-auto"
   xmlns:tools="https://schemas.android.com/tools"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:id="@+id/tableGrid"
   android:layout_gravity="center"
   android:columnCount="4"
   android:orientation="horizontal"
   tools:context=".MainActivity">
   <Button android:text="1" />
   <Button android:text="2" />
   <Button android:text="3" />
   <Button android:text="4" />
   <Button android:text="5" />
   <Button android:text="6" />
   <Button android:text="7" />
   <Button android:text="8" />
   <Button android:text="9" />
   <Button android:text="10" />
   <Button android:text="11" />
   <Button android:text="12" />
   <Button android:text="13" />
   <Button android:text="14" />
   <Button android:text="15" />
   <Button android:text="16" />
</GridLayout>

3단계 − src/MainActivity.java

에 다음 코드 추가
package com.app.sample;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Gravity;
import android.widget.GridLayout;
import android.widget.ImageView;
import android.widget.TableLayout;
public class MainActivity extends AppCompatActivity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      GridLayout gridLayout = (GridLayout)findViewById(R.id.tableGrid);
      gridLayout.removeAllViews();
      int total = 12;
      int column = 5;
      int row = total / column;
      gridLayout.setColumnCount(column);
      gridLayout.setRowCount(row + 1);
      for(int i =0, c = 0, r = 0; i < total; i++, c++){
         if(c == column){
            c = 0;
            r++;
         }
         ImageView oImageView = new ImageView(this);
         oImageView.setImageResource(R.drawable.ic_launcher_background);
         GridLayout.LayoutParams param =new GridLayout.LayoutParams();
         param.height = TableLayout.LayoutParams.WRAP_CONTENT;
         param.width = TableLayout.LayoutParams.WRAP_CONTENT;
         param.rightMargin = 5;
         param.topMargin = 5;
         param.setGravity(Gravity.CENTER);
         param.columnSpec = GridLayout.spec(c);
         param.rowSpec = GridLayout.spec(r);
         oImageView.setLayoutParams (param);
         gridLayout.addView(oImageView);
      }
   }
}

4단계 − Manifests/AndroidManifest.xml에 다음 코드 추가

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="https://schemas.android.com/apk/res/android"
   package="com.app.sample">
   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      android:roundIcon="@mipmap/ic_launcher_round"
      android:supportsRtl="true"
      android:theme="@style/AppTheme">
         <activity android:name=".MainActivity">
            <intent-filter>
               <action android:name="android.intent.action.MAIN" />
               <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
         </activity>
   </application>
</manifest>

응용 프로그램을 실행해 보겠습니다. 실제 Android 모바일 장치를 컴퓨터에 연결했다고 가정합니다. Android 스튜디오에서 앱을 실행하려면 프로젝트의 활동 파일 중 하나를 열고 도구 모음에서 실행 아이콘을 클릭합니다. 모바일 장치를 옵션으로 선택한 다음 기본 화면을 표시할 모바일 장치를 확인하십시오 -

Android에서 GridLayout을 화면 크기에 맞추는 방법은 무엇입니까?