Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Android

จะทำให้ขนาดหน้าจอ GridLayout พอดีกับ Android ได้อย่างไร?


ตัวอย่างนี้สาธิตวิธีทำให้ GridLayout พอดีกับขนาดหน้าจอใน Android

ขั้นตอนที่ 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 studio ให้เปิดไฟล์กิจกรรมของโปรเจ็กต์แล้วคลิกไอคอน Run จากแถบเครื่องมือ เลือกอุปกรณ์มือถือของคุณเป็นตัวเลือก แล้วตรวจสอบอุปกรณ์มือถือของคุณซึ่งจะแสดงหน้าจอเริ่มต้นของคุณ -

จะทำให้ขนาดหน้าจอ GridLayout พอดีกับ Android ได้อย่างไร?