0

アンドロイドでは、私はのような行で使用SqlLiteしています。しかし、私が日付を読んでいるとき、私は私のアンドロイド環境で使用しているので、私は1時間前に日付を取得します。MyDateDATETIME DEFAULT CURRENT_TIMESTAMPGMT + 1

MyDate: 12:03 
Android date: 13:03

SqlLiteどのように私はそれを変換することができますかから読むときGMT + X、Android環境に依存しますか?

編集:

コード:

     Cursor cursor = logsDao.getAll(LogsDao.KEY_ID + " DESC", "100");
            String[] columns = new String[] { LogsDao.KEY_CONTENT, LogsDao.KEY_COMMENT, LogsDao.KEY_CREATED };
            int[] to = new int[] { R.id.logContext, R.id.logComment, R.id.logCreated };
            SimpleCursorAdapter mAdapter = new SimpleCursorAdapter(this, 
            R.layout.log_entry, cursor, columns, to);
            setListAdapter(mAdapter);
4

1 に答える 1

1

最初に、取得したデータを UCT タイムゾーンのタイムスタンプに保存してから、携帯電話のタイムゾーンに合わせて現在のタイムゾーンを更新する必要があると思います。

String s = "2013-02-11 12:03:00";
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
df.setTimeZone(TimeZone.getTimeZone("UCT"));
Date timestamp = null;
try {
    timestamp = df.parse(s);
    df.setTimeZone(TimeZone.getDefault());
} catch (ParseException e) {
    e.printStackTrace();
}

カスタムcursorAdapterを実装し、メソッドbindViewで日付を操作する必要があります

@Override
    public void bindView(View v, Context context, Cursor c) {
        String date;
        date= c.getString(c.getColumnIndex(LogsDao.KEY_CREATED));

        //implement change of timezone

        TextView date_text = (TextView) v.findViewById(R.id.date);
        if (date_text != null) {
            date_text.setText(date);
        }
    }
于 2013-02-11T12:15:25.517 に答える