質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

解決済

データベースより一定数ランダムに取り出したデータをラジオボタンにsetしたい

Haru_T
Haru_T

総合スコア0

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

2回答

0評価

0クリップ

2804閲覧

投稿2016/10/20 07:18

英単語帳アプリを作っています。
その中で意味テストの機能をつけようと思っています。
概要は、データベースより単語をランダムで取り出し、4つのラジオボタンの選択肢から正解だと思う意味を一つを選び、別で用意したボタンを押すことで正誤判定を行い、TextViewに正解や、不正解(+正しい意味)を表示するというような感じです。

そこで、とりあえずの段階で、ランダムに選んンでWordviewに記述した単語の意味をラジオボタン1に、そして別でランダムに3つの(他の単語の)の意味を取り出してきて、ラジオボタン2~4のテキストにsetしようと考えています。

しかし、今のままのコードでは、2~4がすべて同じ結果を表示してしまいます。
SELECT文はラジオボタン一つに対し一つ用意すべきなのでしょうか、、、

それにデータベースより取り出した(正解の意味も含めた)合計4つの意味をラジオボタンにランダムに格納する方法が分かりません。Listを作り Collections.shuffle(リスト名);でシャッフルすべきなのでしょうか、、、

java

public class MeanActivity extends AppCompatActivity { private TextView wordView; @Override protected void onCreate\(Bundle savedInstanceState\) { super\.onCreate\(savedInstanceState\); setContentView\(R\.layout\.activity_mean\); DataBaseHelper dbhelper = new DataBaseHelper\(this\); SQLiteDatabase databaseObject = dbhelper\.getReadableDatabase\(\); String query = "SELECT \* " \+ "FROM WordData order by random\(\)"; String sql = "SELECT \* " \+ "FROM WordData order by random\(\) limit 3"; Cursor cursor = databaseObject\.rawQuery\(query, null\); Cursor cursor1 = databaseObject\.rawQuery\(sql, null\); cursor\.moveToFirst\(\); cursor1\.moveToFirst\(\); String word = cursor\.getString\(0\); String mean1 = cursor\.getString\(3\); String mean2 = cursor1\.getString\(3\); String mean3 = cursor1\.getString\(3\); String mean4 = cursor1\.getString\(3\); wordView = \(TextView\) findViewById\(R\.id\.word_view\); wordView\.setText\(word\); RadioButton rg1 = \(RadioButton\) findViewById\(R\.id\.RadioButton1\); rg1\.setText\(mean1\); RadioButton rg2 = \(RadioButton\) findViewById\(R\.id\.RadioButton2\); RadioButton rg3 = \(RadioButton\) findViewById\(R\.id\.RadioButton3\); RadioButton rg4 = \(RadioButton\) findViewById\(R\.id\.RadioButton4\); rg2\.setText\(mean2\); rg3\.setText\(mean3\); rg4\.setText\(mean4\); } }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。