[Android Studio 30天自我挑战] RadioGroup,RadioButton元件介绍

RaidioButton为单选元件,然而RadioGroup则是放RadioButton的选项
如果RadioButton没有被放在RadioGroup里则会变成复选,因此在放入RadioButton前要先新增RadioGroup。

接着用简单的范例介绍RadioButton的用法:
先选取当前的温度单位,透过editText输入数值後换算
xml档如下:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">
    <TextView
        android:id="@+id/textView"
        android:layout_width="85dp"
        android:layout_height="33dp"
        android:layout_marginTop="52dp"
        android:text="@string/input"
        android:textSize="20sp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.205"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
    <EditText
        android:id="@+id/value"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:ems="10"
        android:inputType="number"
        android:hint="@string/number"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.432"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.185" />
    <TextView
        android:id="@+id/degC"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/charC"
        android:textSize="50sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.761"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
    <TextView
        android:id="@+id/degF"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/charF"
        android:textSize="50sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.755"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.34" />
    <RadioGroup
        android:id="@+id/unit"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="40dp"
        android:orientation="horizontal"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toEndOf="@+id/textView"
        app:layout_constraintTop_toTopOf="parent">
        <RadioButton
            android:id="@+id/unitF"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:checked="true"
            android:gravity="start"
            android:text="华氏"
            android:textSize="20sp" />
        <RadioButton
            android:id="@+id/uniC"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="end"
            android:text="摄氏"
            android:textAlignment="textEnd"
            android:textSize="20sp" />

    </RadioGroup>

</androidx.constraintlayout.widget.ConstraintLayout>

因为摄氏及华氏的符号所以我们在res/values/String.xml档下新增

<string name="app_name">温度计算</string>
<string name="input">输入温度</string>
<string name="number">请输入温度</string>
<string name="charF">"\u2109"</string>
<string name="charC">"\u2103"</string>

这样就可以在画面中显示出度C及度F的符号了
接着打开MainActivity.java
先宣告需要用到的RadioGroup以及editText的值
透过calc来换算温度的值,接着利用afterTextChanged来直接显示於TextView上

package com.example.itradiobtn;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.widget.EditText;
import android.widget.RadioGroup;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener, TextWatcher {

    RadioGroup unit;
    EditText value;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        unit = findViewById(R.id.unit);
        unit.setOnCheckedChangeListener(this);

        value = findViewById(R.id.value);
        value.addTextChangedListener(this);
    }
    @Override
    public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {
    }
    @Override
    public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
    }
    @Override
    public void afterTextChanged(Editable editable) {
        calc();
    }
    @Override
    public void onCheckedChanged(RadioGroup radioGroup, int i) {
        calc();
    }

    private void calc() {
        TextView degF = findViewById(R.id.degF);
        TextView degC = findViewById(R.id.degC);

        double f, c;
        if (unit.getCheckedRadioButtonId() == R.id.unitF) {
            if (value.getText().toString().length() ==0)
                return;
            else {
                f = Double.parseDouble(value.getText().toString());
                c = (f - 32) * 5 / 9;
            }
        } else {
            if (value.getText().toString().length() ==0)
                return;
            else {
                c = Double.parseDouble(value.getText().toString());
                f = c * 9 / 5 + 32;}
        }
        degC.setText(String.format("%.1f", c) + getResources().getString(R.string.charC));
        degF.setText(String.format("%.1f", f) + getResources().getString(R.string.charF));

    }
}

显示结果为:
https://ithelp.ithome.com.tw/upload/images/20210930/20139258LYMuEPc6bh.png
https://ithelp.ithome.com.tw/upload/images/20210930/20139258Kt9xrDrT6y.png
https://ithelp.ithome.com.tw/upload/images/20210930/20139258Yv0SDMz5GA.png


<<:  [Genero 4.00] 新上线,语言动态化(VAR)+自适应画面

>>:  Day 16 撰写一个 dockerfile,和 vue-cli 服务进行整合开发

[2021铁人赛 Day21] General Skills 18

引言 今天是我们 General Skills 最後一题,光是基础技能我们就花了 21 天呢......

D08 / 怎麽做自己的 Modifier.padding? - Custom Layout Modifier

今天大概会聊到的范围 layout modifier 上一次讨论到 Modifier 时,觉得自己...

如何用 Apps Script 寄出客制化的 Google 表单并搜集分散在 Google Sheet 中的回应?(三)一次搜集很多 Google Form 内的回应

今天的目标 很多时候我们会需要搜集些不同的资料。像是 Marketing 在做大规模但针对不同组织的...

一个人在一年写一套ERP程序

一个人在一年写一套ERP程序, 可能吗? 笔者是朝正面且乐观看待此事,认为一个人在一年内写一套ERP...

Day06【JS】「...」展开运算符 & 其余运算符

「展开运算符」与「其余运算符」, 两者的表示方式都是 ..., 以下分别说明。 展开运算符 展开运算...