Альтернативная опция для onClick () для переключателя в Android Studio - PullRequest
0 голосов
/ 14 марта 2020

Я пытался создать приложение для викторины, используя RadioGroups для каждого вопроса, имеющего 4 варианта. Я сделал приложение, чтобы вычислить оценку пользователя, поддерживая указатель для правильных и неправильных выбранных ответов. Например, в моем первом задании есть 8 вопросов, каждый из которых содержит свои радиогруппы для ответов. Если пользователь выбирает правильный вариант, указатель для правильного ответа увеличивается, и то же самое происходит для неправильных ответов. В конце концов, окончательная оценка этого действия рассчитывается и предназначена для следующего действия.

Код для всей MainActivity:

package com.example.myapplicationthreesubjectquiz;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.os.strictmode.WebViewMethodCalledOnWrongThreadViolation;
import android.view.View;
import android.widget.Button;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    public int correctAnsBio=0, wrongAnsBio=0;
    public RadioGroup rgbq1, rgbq2, rgbq3, rgbq4, rgbq5, rgbq6, rgbq7, rgbq8;
    public RadioButton rbbq1, rbbq2, rbbq3, rbbq4, rbbq5, rbbq6, rbbq7, rbbq8;
    public int corbq1, corbq2, corbq3, corbq4, corbq5, corbq6, corbq7, corbq8;

    Button moveToChemistry;

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

        rgbq1 = findViewById(R.id.rgbq1);
        rgbq2 = findViewById(R.id.rgbq2);
        rgbq3 = findViewById(R.id.rgbq3);
        rgbq4 = findViewById(R.id.rgbq4);
        rgbq5 = findViewById(R.id.rgbq5);
        rgbq6 = findViewById(R.id.rgbq6);
        rgbq7 = findViewById(R.id.rgbq7);
        rgbq8 = findViewById(R.id.rgbq8);

        moveToChemistry = findViewById(R.id.moveToChemistry);

        corbq1 = 1;
        corbq2 = 1;
        corbq3 = 1;
        corbq4 = 1;
        corbq5 = 1;
        corbq6 = 1;
        corbq7 = 1;
        corbq8 = 1;



        moveToChemistry.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                final int scoreInBio = (4*correctAnsBio)+((-1)*wrongAnsBio);
                Intent intent = new Intent(MainActivity.this, com.example.myapplicationthreesubjectquiz.chemistry.class);
                intent.putExtra("bioScore", scoreInBio);
                startActivity(intent);

            }
        });


    }

    public void clickedBq1(View v){

        int selected = -1;

        switch(rgbq1.getCheckedRadioButtonId())
        {
            case R.id.rbbq1o1:
                selected = 1;
                break;
            case R.id.rbbq1o2:
                selected = 2;
                break;
            case R.id.rbbq1o3:
                selected = 3;
                break;
            case R.id.rbbq1o4:
                selected = 4;
                break;
        }

        if(selected == corbq1)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq1)
        {
            wrongAnsBio++;
        }


    }
    public void clickedBq2(View v){

        int selected = -1;

        switch(rgbq2.getCheckedRadioButtonId())
        {
            case R.id.rbbq2o1:
                selected = 1;
                break;
            case R.id.rbbq2o2:
                selected = 2;
                break;
            case R.id.rbbq2o3:
                selected = 3;
                break;
            case R.id.rbbq2o4:
                selected = 4;
                break;
        }

        if(selected == corbq2)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq2)
        {
            wrongAnsBio++;
        }

    }
    public void clickedBq3(View v){

        int selected = -1;

        switch(rgbq3.getCheckedRadioButtonId())
        {
            case R.id.rbbq3o1:
                selected = 1;
                break;
            case R.id.rbbq3o2:
                selected = 2;
                break;
            case R.id.rbbq3o3:
                selected = 3;
                break;
            case R.id.rbbq2o4:
                selected = 4;
                break;
        }

        if(selected == corbq3)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq3)
        {
            wrongAnsBio++;
        }

    }

    public void clickedBq4(View v){

        int selected = -1;

        switch(rgbq4.getCheckedRadioButtonId())
        {
            case R.id.rbbq4o1:
                selected = 1;
                break;
            case R.id.rbbq4o2:
                selected = 2;
                break;
            case R.id.rbbq4o3:
                selected = 3;
                break;
            case R.id.rbbq4o4:
                selected = 4;
                break;
        }

        if(selected == corbq4)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq4)
        {
            wrongAnsBio++;
        }

    }
    public void clickedBq5(View v){

        int selected = -1;

        switch(rgbq5.getCheckedRadioButtonId())
        {
            case R.id.rbbq5o1:
                selected = 1;
                break;
            case R.id.rbbq5o2:
                selected = 2;
                break;
            case R.id.rbbq5o3:
                selected = 3;
                break;
            case R.id.rbbq5o4:
                selected = 4;
                break;
        }

        if(selected == corbq5)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq5)
        {
            wrongAnsBio++;
        }

    }
    public void clickedBq6(View v){

        int selected = -1;

        switch(rgbq6.getCheckedRadioButtonId())
        {
            case R.id.rbbq6o1:
                selected = 1;
                break;
            case R.id.rbbq6o2:
                selected = 2;
                break;
            case R.id.rbbq6o3:
                selected = 3;
                break;
            case R.id.rbbq6o4:
                selected = 4;
                break;
        }

        if(selected == corbq6)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq6)
        {
            wrongAnsBio++;
        }

    }
    public void clickedBq7(View v){

        int selected = -1;

        switch(rgbq7.getCheckedRadioButtonId())
        {
            case R.id.rbbq7o1:
                selected = 1;
                break;
            case R.id.rbbq7o2:
                selected = 2;
                break;
            case R.id.rbbq7o3:
                selected = 3;
                break;
            case R.id.rbbq7o4:
                selected = 4;
                break;
        }

        if(selected == corbq7)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq7)
        {
            wrongAnsBio++;
        }

    }
    public void clickedBq8(View v){

        int selected = -1;

        switch(rgbq8.getCheckedRadioButtonId())
        {
            case R.id.rbbq8o1:
                selected = 1;
                break;
            case R.id.rbbq8o2:
                selected = 2;
                break;
            case R.id.rbbq8o3:
                selected = 3;
                break;
            case R.id.rbbq8o4:
                selected = 4;
                break;
        }

        if(selected == corbq8)
        {
            correctAnsBio++;
        }
        else if(selected >0 && selected != corbq8)
        {
            wrongAnsBio++;
        }

    }
}

Теперь проблема заключается в том, что если пользователь сначала выбирает неправильный параметр, а затем меняет его на правильный, оба указателя неправильных и правильных ответов увеличиваются. Я использовал атрибут onClick в коде XML для кнопок RadioButton. Вероятно, должен быть какой-то другой атрибут, чтобы просто показать опцию, чтобы получить окончательно проверенную опцию вместо того, чтобы это происходило снова и снова.

Ниже приведен код XML:

<RadioGroup
     android:id="@+id/rgbq1"
     android:layout_width="match_parent"
     android:layout_height="wrap_content"
     android:layout_marginLeft="14dp">

     <RadioButton
            android:id="@+id/rbbq1o1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:buttonTint="@color/colorPrimary"
            android:onClick="clickedBq1"
            android:text="Option1"
            android:textColor="@color/colorPrimaryVariant"
            android:textSize="20sp" />

Ответы [ 2 ]

0 голосов
/ 14 марта 2020

Вы должны указать переменную, чтобы проверить, отвечали ли вы раньше или нет (предыдущий ответ является истинным или ложным).

Пример метода clickedBq1 .

public void clickedBq1(View v){
        int selected = -1;
        boolean statusAnswer = false
        switch(rgbq1.getCheckedRadioButtonId())
        {
            case R.id.rbbq1o1:
                selected = 1;
                break;
            case R.id.rbbq1o2:
                selected = 2;
                break;
            case R.id.rbbq1o3:
                selected = 3;
                break;
            case R.id.rbbq1o4:
                selected = 4;
                break;
        }

        if(statusAnswer == false)
        {
            if(selected == corbq1)
            {
                correctAnsBio++;
            }
            else if(selected >0 && selected != corbq1)
            {
                wrongAnsBio++;
            }
            statusAnswer == true
        }
        else
        {
            if(selected == corbq1)
            {
                correctAnsBio++;
                wrongAnsBio--;
            }
            else if(selected >0 && selected != corbq1)
            {
                wrongAnsBio++;
                correctAnsBio--;
            }
        }
    }
0 голосов
/ 14 марта 2020

Вы можете добавить переключатель прослушивания переключателей

RadioGroup radioGroup = (RadioGroup) findViewById(R.id.RadioGroup);        
radioGroup.setOnCheckedChangeListener(new OnCheckedChangeListener() 
{
    @Override
    public void onCheckedChanged(RadioGroup group, int checkedId) {
        // checkedId is the RadioButton selected
    }
})

или получить выбранный переключатель при следующем нажатии кнопки. как ниже

    next.setOnClickListener(new OnClickListener(View v){
        String value =
            ((RadioButton)findViewById(rg.getCheckedRadioButtonId()))
            .getText().toString();
          // here you can compare the selected answer is  correct or not     
     });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...