Моя деятельность не открывается при работе с базой данных SQLite - PullRequest
0 голосов
/ 29 ноября 2018

В настоящее время следует учебному руководству YouTube, касающемуся приложения для викторины в Android с интеграцией SQLite.Ссылка здесь: https://www.youtube.com/watch?v=pEDVdSUuWXE

Я следил за ним до мельчайших деталей, но когда я запускаю свое приложение на своем эмуляторе в Android Studio, предполагаемая активность не запускается, когда я нажимаю кнопку наначало деятельности.Кроме того, моя база данных SQLite не будет вставлять в нее данные, жестко закодированные с использованием Java-класса QuizActivity.

Вот мой код

QuizDBHelper.java

package com.faith.mobilequiz;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import com.faith.mobilequiz.QuizContract.*;

import java.util.ArrayList;
import java.util.List;

public class QuizDBHelper extends SQLiteOpenHelper {
    private static final String DATABASE_NAME = "MobileQuiz.db";
    private static final int DATABASE_VERSION = 1;

    private SQLiteDatabase db;

     public QuizDBHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
         this.db = db;

        final String SQL_CREATE_QUESTIONS_TABLE = "CREATE TABLE " +
                QuestionsTable.TABLE_NAME + " ( " +
                QuestionsTable._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
                QuestionsTable.COLUMN_QUESTION + " TEXT, " +
                QuestionsTable.COLUMN_OPTION1 + " TEXT, " +
                QuestionsTable.COLUMN_OPTION2 + " TEXT, " +
                QuestionsTable.COLUMN_OPTION3 + " TEXT, " +
                QuestionsTable.COLUMN_ANSWER_NUMBER + " INTEGER " +
                ")";

         db.execSQL(SQL_CREATE_QUESTIONS_TABLE);
         fillQuestionsTable();

    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
          db.execSQL("DROP TABLE IF EXISTS " + QuestionsTable.TABLE_NAME);
          onCreate(db);
    }

    private void fillQuestionsTable() {
        Question q1 = new Question("A is correct", "A", "B", "C", 1);
        addQuestion(q1);
        Question q2 = new Question("B is correct", "A", "B", "C", 2);
        addQuestion(q2);
        Question q3 = new Question("C is correct", "A", "B", "C", 3);
        addQuestion(q3);
        Question q4 = new Question("A is correct again", "A", "B", "C", 1);
        addQuestion(q4);
        Question q5 = new Question("B is correct again", "A", "B", "C", 2);
        addQuestion(q5);
    }

    private void addQuestion(Question question) {
        ContentValues cv = new ContentValues();
        cv.put(QuestionsTable.COLUMN_QUESTION, question.getQuestion());
        cv.put(QuestionsTable.COLUMN_OPTION1, question.getOption1());
        cv.put(QuestionsTable.COLUMN_OPTION2, question.getOption2());
        cv.put(QuestionsTable.COLUMN_OPTION3, question.getOption3());
        cv.put(QuestionsTable.COLUMN_ANSWER_NUMBER, question.getAnswerNum());
        db.insert(QuestionsTable.TABLE_NAME, null, cv);
    }

    public List<Question> getAllQuestions() {
         List<Question> questionList = new ArrayList<>();
         db = getReadableDatabase();
         Cursor c = db.rawQuery("SELECT * FROM " + QuestionsTable.TABLE_NAME, null);

         if(c.moveToFirst()) {
             do {
                 Question question = new Question();
                 question.setQuestion(c.getString(c.getColumnIndex(QuestionsTable.COLUMN_QUESTION)));
                 question.setOption1(c.getString(c.getColumnIndex(QuestionsTable.COLUMN_OPTION1)));
                 question.setOption2(c.getString(c.getColumnIndex(QuestionsTable.COLUMN_OPTION2)));
                 question.setOption3(c.getString(c.getColumnIndex(QuestionsTable.COLUMN_OPTION3)));
                 question.setAnswerNum(c.getInt(c.getColumnIndex(QuestionsTable.COLUMN_ANSWER_NUMBER)));
                 questionList.add(question);
             } while(c.moveToNext());
         }

         c.close();
         return questionList;


    }
}

Это для QuizActivity.java

package com.faith.mobilequiz;

import android.content.res.ColorStateList;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Button;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.TextView;

import java.util.Collections;
import java.util.List;

public class QuizActivity extends AppCompatActivity {
    private TextView textViewQuestion;
    private TextView textViewScore;
    private TextView textViewQuestionCount;
    private TextView textViewTimer;
    private RadioGroup rbGroup;
    private RadioButton rb1;
    private RadioButton rb2;
    private RadioButton rb3;
    private Button buttonConfirmNext;

    private ColorStateList textColorDefaultRb;

    private List<Question> questionList;
    private int questionCounter;
    private int questionCountTotal;
    private Question currentQuestion;

    private int score;
    private boolean answered;

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

        textViewQuestion = findViewById(R.id.txtQuestion);
        textViewScore = findViewById(R.id.txtScore);
        textViewQuestionCount = findViewById(R.id.txtQuestionCount);
        textViewTimer = findViewById(R.id.txtTimer);
        rbGroup = findViewById(R.id.radioGroup);
        rb1 = findViewById(R.id.radioBtn1);
        rb2 = findViewById(R.id.radioBtn2);
        rb3 = findViewById(R.id.radioBtn3);
        buttonConfirmNext = findViewById(R.id.btnConfirmNext);

        textColorDefaultRb = rb1.getTextColors();

        QuizDBHelper dbHelper = new QuizDBHelper(this);
        questionList = dbHelper.getAllQuestions();
        questionCountTotal = questionList.size();
        Collections.shuffle(questionList);

        showNextQuestion();

    }

    private void showNextQuestion() {
        rb1.setTextColor(textColorDefaultRb);
        rb2.setTextColor(textColorDefaultRb);
        rb3.setTextColor(textColorDefaultRb);
        rbGroup.clearCheck();

        if(questionCounter < questionCountTotal) {
            currentQuestion = questionList.get(questionCounter);

            textViewQuestion.setText(currentQuestion.getQuestion());
            rb1.setText(currentQuestion.getOption1());
            rb2.setText(currentQuestion.getOption2());
            rb3.setText(currentQuestion.getOption3());
            questionCounter++;
            textViewQuestionCount.setText("Question: " + questionCounter + "/" + questionCountTotal);
            answered = false;
            buttonConfirmNext.setText("Confirm");

        } else {
            finishQuiz();
        }
    }

    private void finishQuiz() {
        finish();
    }
}

Что-то не так с запросом?

1 Ответ

0 голосов
/ 30 ноября 2018

Что-то не так с запросом?

Нет.

Код, который вы скопировали и протестировали, в порядке.

Использование действия MainActivity, состоящего всего лишь из кнопки, которую можно нажать для запуска действия теста, запускает действие теста с вопросом.

Использование кнопки «Назад» для возврата к основному действию и нажатия кнопкикнопка отображает следующий вопрос.

В основном задании, которое у меня есть: -

public class MainActivity extends AppCompatActivity {
    Button mQuizButton;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
        mQuizButton = this.findViewById(R.id.quizbutton);
        mQuizButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent i = new Intent(MainActivity.this,QuizActivity.class);
                startActivity(i);
            }
        });
    }
}

Проблема может заключаться в том, что вы не определили QuizActivity вманифест.

например: -

<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=".QuizActivity">
    </activity>
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

т.е. то, что вам нужно

    <activity android:name=".QuizActivity">
    </activity>

Чтобы определить QuizActivity как действие, которое затем можно запустить.

Кроме того, моя база данных SQLite не будет вставлять в нее данные, жестко закодированные с использованием Java-класса QuizActivity.

Этого не произошло бы, если бы к базе данных обращались только в QuizActivity,

  • , учитывая, что простое создание экземпляра QuizDBHelper на самом деле не создает базу данных,

, пока не будет предпринята попыткаи база данных с возможностью записи или чтения (это может быть неявно с помощью метода SQliteDatabase или может быть явным с помощью getWritableDatabase или getReadableDatabase), что база данных создана и что вызывается метод onCreate, затем добавляются жестко закодированные вопросы (они добавляют их).

Поэтому я считаю, что вам просто необходимо отредактировать файл манифеста AndroidManifest.xml соответственно.

Лучше всего удалить данные приложений или удалить приложение перед повторным запуском.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...