在生活,学习中每天都要学习,社会中也有许多的各行各业的做题软件,今天分享使用鸿蒙系统开发做题类的应用软件学习,页面比较简单,终点在RadioButton和CheckBox组件的学习以及功能的完成,其效果如下:

HarmonyOS tabs组件 JS_ios


先看单选题,使用的是RadioButton组件,但必须要套在RadioContainer组件中才能实现单选效果,并设定选中选项改变字体颜色,将选项填写在小括号内:

在这里插入图片描述

HarmonyOS tabs组件 JS_android_02


HarmonyOS tabs组件 JS_ios_03


接下来看多选题,这里使用CheckBox组件完成多选功能,将选中的选项填写在小括号内,如果选错了,临时修改答案,也会同步刷新小括号内的选项:

HarmonyOS tabs组件 JS_HarmonyOS tabs组件 JS_04


假设取消一个C选项,那么界面效果是如下:

HarmonyOS tabs组件 JS_HarmonyOS tabs组件 JS_05


继续取消或者添加选项都是可以进行同步刷新,这里只是学习的小案例,如果你觉得能掌握了,那么你离开发一个完整的题库软件更进一步了,甚至你可以举一反三,根据自己的想法把它做的更好。

接下来我们上代码,先看一下布局的代码:

<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout
    xmlns:ohos="http://schemas.huawei.com/res/ohos"
    ohos:height="match_parent"
    ohos:width="match_parent"
    ohos:orientation="vertical">
    <Text
        ohos:height="match_content"
        ohos:width="match_parent"
        ohos:text="面试宝典"
        ohos:text_size="35vp"
        ohos:text_color="#fff"
        ohos:text_alignment="center"
        ohos:background_element="#FF3333EC"/>
    <DirectionalLayout
        ohos:height="match_content"
        ohos:width="match_parent"
        ohos:weight="1">

        <Text
            ohos:height="match_content"
            ohos:width="match_parent"
            ohos:text="单选题"
            ohos:text_size="30vp"/>

        <Text
            ohos:id="$+id:tv5"
            ohos:height="match_content"
            ohos:width="match_parent"
            ohos:multiple_lines="true"
            ohos:text="1.下列哪个终端设备系统不是移动互联端的系统的技术?()"
            ohos:text_size="25vp"/>

        <RadioContainer
            ohos:id="$+id:rc_title"
            ohos:height="match_content"
            ohos:width="match_parent">

            <RadioButton
                ohos:height="match_content"
                ohos:width="match_content"
                ohos:check_element="null"
                ohos:text="A.Android"
                ohos:text_color_on="#f00"
                ohos:text_size="22vp"/>

            <RadioButton
                ohos:height="match_content"
                ohos:width="match_content"
                ohos:check_element="null"
                ohos:text="B.IOS"
                ohos:text_color_on="#f00"
                ohos:text_size="22vp"/>

            <RadioButton
                ohos:height="match_content"
                ohos:width="match_content"
                ohos:check_element="null"
                ohos:text="C.JavaEE"
                ohos:text_color_on="#f00"
                ohos:text_size="22vp"/>

            <RadioButton
                ohos:height="match_content"
                ohos:width="match_content"
                ohos:check_element="null"
                ohos:text="D.HarMonyOS"
                ohos:text_color_on="#f00"
                ohos:text_size="22vp"/>
        </RadioContainer>
    </DirectionalLayout>

    <DirectionalLayout
        ohos:height="match_content"
        ohos:width="match_parent"
        ohos:weight="1">

        <Text
            ohos:height="match_content"
            ohos:width="match_parent"
            ohos:text="多选题"
            ohos:text_size="30vp"/>

        <Text
            ohos:id="$+id:tv6"
            ohos:height="match_content"
            ohos:width="match_parent"
            ohos:multiple_lines="true"
            ohos:text="2.下列哪些是Java面向对象的三大特征?()"
            ohos:text_size="25vp"/>

        <Checkbox
            ohos:id="$+id:cb1"
            ohos:height="match_content"
            ohos:width="match_content"
            ohos:check_element="null"
            ohos:text="A.封装"
            ohos:text_color_on="#f00"
            ohos:text_size="22vp"/>

        <Checkbox
            ohos:id="$+id:cb2"
            ohos:height="match_content"
            ohos:width="match_content"
            ohos:check_element="null"
            ohos:text="B.接口"
            ohos:text_color_on="#f00"
            ohos:text_size="22vp"/>

        <Checkbox
            ohos:id="$+id:cb3"
            ohos:height="match_content"
            ohos:width="match_content"
            ohos:check_element="null"
            ohos:text="C.继承"
            ohos:text_color_on="#f00"
            ohos:text_size="22vp"/>

        <Checkbox
            ohos:id="$+id:cb4"
            ohos:height="match_content"
            ohos:width="match_content"
            ohos:check_element="null"
            ohos:text="D.多态"
            ohos:text_color_on="#f00"
            ohos:text_size="22vp"/>

    </DirectionalLayout>

</DirectionalLayout>

这里整个页面使用的是DirectionalLayout线性布局,里面使用了两个DirectionalLayout线性布局将整个页面平均一份为二,上半部分用于单选题,下半部分用于多选题。
上半部分中使用了两个Text组件显示题目和题型,接着使用了RadioContainer组件包裹了四个RadioButton组件实现单选功能,并给这些单选按钮添加了选中的字体颜色。
下半部分中也是使用了两个Text组件显示题目和题型,接着使用了四个CheckBox组件显示选项。
相信大家已经了解了布局的整个搭建的结构,那现在最主要的就是怎么实现做题的功能,下面上java代码:

package com.example.hm_phone_java.slice;

import com.example.hm_phone_java.ResourceTable;
import ohos.aafwk.ability.AbilitySlice;
import ohos.aafwk.content.Intent;
import ohos.agp.components.*;


public class RadioCheckAbilitySlice extends AbilitySlice {
    //将四个多选按钮的id定义出来
    private int[] ids = {ResourceTable.Id_cb1,
            ResourceTable.Id_cb2,
            ResourceTable.Id_cb3,
            ResourceTable.Id_cb4};
    //定义可以存储多选按钮的数组
    private Checkbox[] cbs = new Checkbox[ids.length];
    //用于存储多选题的答案
    private String[] content=new String[ids.length];
    @Override
    protected void onStart(Intent intent) {
        super.onStart(intent);
        //加载布局
        this.setUIContent(ResourceTable.Layout_ability_radio_checkbox);
        //获得单选题和多选题的题目组件
        Text tv5 = (Text) this.findComponentById(ResourceTable.Id_tv5);
        Text tv6 = (Text) this.findComponentById(ResourceTable.Id_tv6);
        //获得单选按钮的容器组件
        RadioContainer rc = (RadioContainer) this.findComponentById(ResourceTable.Id_rc_title);
        //添加单选按钮的选项改变事件监听器
        rc.setMarkChangedListener(new RadioContainer.CheckedStateChangedListener() {
            @Override
            public void onCheckedChanged(RadioContainer radioContainer, int i) {
                //获得当前被选中的单选按钮组件
                RadioButton rb = (RadioButton) radioContainer.getComponentAt(i);
                //截取部分题目将选中的答案进行拼接显示在Text组件上
                String title = tv5.getText();
                title = title.substring(0, title.indexOf("(") + 1);
                tv5.setText(title + rb.getText().substring(0, 1) + ")");
            }
        });
        //循环遍历,进行初始化多选按钮,这里使用循环是简化代码,避免编写过多的重复代码,
        // 如果有更好的办法能节省代码的,欢迎大家分享技术
        for (int i = 0; i < ids.length; i++) {
            cbs[i]= (Checkbox) this.findComponentById(ids[i]);
            //将每一个多选按钮的下标存储在对应的多选按钮的组件上
            cbs[i].setName(String.valueOf(i));
            //给每一个多选按钮添加选中监听器
            cbs[i].setCheckedStateChangedListener(new AbsButton.CheckedStateChangedListener() {
                @Override
                public void onCheckedChanged(AbsButton absButton, boolean b) {
                    Checkbox cb= (Checkbox) absButton;
                    if (b)
                        //当前多选按钮被选中,将该选项的答案保存是字符串数组的对应下标位置
                        content[Integer.parseInt(cb.getName())]=cb.getText().substring(0,1);
                    else
                        //当前选项被取消,那么从字符串数组中删除对应下标上的答案
                        content[Integer.parseInt(cb.getName())]="";

                    String title = tv6.getText();
                    title = title.substring(0, title.indexOf("(") + 1);
                    StringBuilder builder=new StringBuilder();
                    //将选中的答案用StringBuilder对象进行拼接成字符串
                    for(String info:content){
                        if (info!=null&&!"".equals(info))
                            builder.append(info).append(",");
                    }
                    //并将最后的答案显示在文本组件上
                    tv6.setText(title + builder.toString().substring(0,builder.length()-1) + ")");
                }
            });
        }

    }
}

这篇文章就分享到这里,感谢大家的关注和阅读,后期文章会更精彩!!!