複数のビューで使用する必要があるデータベースの値を更新する関数を作成しました。現在、各クラスには独自のコードのコピーがあります。基本的には値を読み込んだ後、テキストビューを更新したいと思います。別のクラスからの呼び出し参照(TextView)findViewByIdの方法
私は仕事をしているDisplayTopのクラスを作りました。しかし、どういうわけか、私は(TextView)findViewByIdを私が思う関数上に送信する必要があります。私はこの権利を言いたいと思う。では、これに対する呼び出しと、(TextView)findViewByIdを解決する方法について説明します。助けてくれてありがとう!
public void DisplayTop2()
{
int UserID = 1;
String D=Fun.getCurrentDateString();
String Sql;
Double a = 0.0;
Double b = 0.0;
SQLiteDatabase Db;
String myPath = DB_PATH + DB_NAME;
Db = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);
Sql =" SELECT a,b " +
" FROM test " +
" where Dte = '" + D + "' and UserID = " + UserID;
try {
Cursor c = Db.rawQuery(Sql, null);
if (c != null) {
if (c.moveToFirst()) {
do {
a += (c.getDouble(c.getColumnIndex("a")));
b += (c.getDouble(c.getColumnIndex("b")));
}while (c.moveToNext());
}
}
c.close();
} catch (Exception e) {
}
Db.close();
// Here is where the problem is. The real app has 5 fields.
// I can pass the R.id.a
// But how do I pass the reference to findViewById to the activity that called this
TextView tvt4 = (TextView)findViewById(R.id.a);
D = Fun.round(a,1,BigDecimal.ROUND_HALF_UP);
tvt4.setText(D) ;
tvt4 = (TextView)findViewById(R.id.b);
D = Fun.round(b,1,BigDecimal.ROUND_HALF_UP);
tvt4.setText(D) ;
};
もう1つの方法は、アクティビティからコンテキストを渡すことですが、あなたのソリューションははるかにクリーンです。 – sgarman
、またはアクティビティ自体を渡すこともありますが、これは時に便利ですが、@ dave.cのソリューションは最もエレガントです。 – mdelolmo
私がここに追加したコードは短いです。色の変更などが必要な5つのフィールドがあり、それぞれのアクティビティに約30行のコードが必要です。だから、そのコードは基本的に各活動に重複していますか?私はそのすべてを1か所で行う機能を作りようとしていました。しかしそれをそのまま残しておく方がずっと簡単です:) –