android studio 将数据库里储存的时间调用出来继续计时
时间: 2023-11-02 18:37:17 浏览: 29
可以使用Java中的Date和Calendar类来实现。先将数据库里储存的时间转换成Date格式,然后使用Calendar类的setTime()方法将其设置为当前的时间,再使用Calendar类的getTimeInMillis()方法获取自1970年1月1日以来的毫秒数,最后计算时间差即可继续计时。
相关问题
android studio 计时器暂停后将时间保存到SQLite数据库
要将计时器暂停后将时间保存到SQLite数据库,您可以按照以下步骤操作:
1. 声明一个变量来保存计时器的当前时间,例如long currentTime。
2. 在计时器的onTick方法中每次更新currentTime变量。
3. 在计时器暂停的时候,将currentTime保存到SQLite数据库中。您可以使用ContentValues类来创建一个包含currentTime的数据行,然后使用SQLiteOpenHelper类的insert方法将其插入到数据库中。
4. 在恢复计时器时,从SQLite数据库中获取之前保存的currentTime值,并使用它来重新开始计时器。
下面是一个示例代码,演示如何实现这个功能:
```java
public class MainActivity extends AppCompatActivity {
private CountDownTimer mCountDownTimer;
private TextView mTextViewCountdown;
private Button mButtonStartPause;
private Button mButtonReset;
private boolean mTimerRunning;
private long mTimeLeftInMillis;
private long mEndTime;
private SQLiteDatabase mDatabase;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mTextViewCountdown = findViewById(R.id.text_view_countdown);
mButtonStartPause = findViewById(R.id.button_start_pause);
mButtonReset = findViewById(R.id.button_reset);
mButtonStartPause.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mTimerRunning) {
pauseTimer();
} else {
startTimer();
}
}
});
mButtonReset.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
resetTimer();
}
});
// Initialize the database
DBHelper dbHelper = new DBHelper(this);
mDatabase = dbHelper.getWritableDatabase();
// Load the saved time from the database
Cursor cursor = mDatabase.query(DBHelper.TABLE_NAME, null, null, null, null, null, null);
if (cursor.moveToFirst()) {
mTimeLeftInMillis = cursor.getLong(cursor.getColumnIndex(DBHelper.COLUMN_TIME_LEFT));
updateCountdownText();
startTimer();
} else {
resetTimer();
}
cursor.close();
}
private void startTimer() {
mEndTime = System.currentTimeMillis() + mTimeLeftInMillis;
mCountDownTimer = new CountDownTimer(mTimeLeftInMillis, 1000) {
@Override
public void onTick(long millisUntilFinished) {
mTimeLeftInMillis = millisUntilFinished;
updateCountdownText();
}
@Override
public void onFinish() {
mTimerRunning = false;
mButtonStartPause.setText("Start");
mButtonStartPause.setVisibility(View.INVISIBLE);
mButtonReset.setVisibility(View.VISIBLE);
}
}.start();
mTimerRunning = true;
mButtonStartPause.setText("Pause");
mButtonReset.setVisibility(View.INVISIBLE);
}
private void pauseTimer() {
mCountDownTimer.cancel();
mTimerRunning = false;
mButtonStartPause.setText("Start");
mButtonReset.setVisibility(View.VISIBLE);
// Save the current time to the database
ContentValues values = new ContentValues();
values.put(DBHelper.COLUMN_TIME_LEFT, mTimeLeftInMillis);
mDatabase.update(DBHelper.TABLE_NAME, values, null, null);
}
private void resetTimer() {
mTimeLeftInMillis = 60000;
updateCountdownText();
mButtonStartPause.setVisibility(View.VISIBLE);
mButtonReset.setVisibility(View.INVISIBLE);
// Save the default time to the database
ContentValues values = new ContentValues();
values.put(DBHelper.COLUMN_TIME_LEFT, mTimeLeftInMillis);
mDatabase.insert(DBHelper.TABLE_NAME, null, values);
}
private void updateCountdownText() {
int minutes = (int) (mTimeLeftInMillis / 1000) / 60;
int seconds = (int) (mTimeLeftInMillis / 1000) % 60;
String timeLeftFormatted = String.format(Locale.getDefault(), "%02d:%02d", minutes, seconds);
mTextViewCountdown.setText(timeLeftFormatted);
}
private static class DBHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "timer.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "timer";
private static final String COLUMN_TIME_LEFT = "time_left";
private static final String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME + " (" +
COLUMN_TIME_LEFT + " INTEGER)";
private static final String DROP_TABLE = "DROP TABLE IF EXISTS " + TABLE_NAME;
public DBHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL(DROP_TABLE);
onCreate(db);
}
}
}
```
在这个示例中,我们在onCreate方法中初始化了SQLite数据库,并在恢复计时器时从中加载了之前保存的时间。当暂停计时器时,我们使用ContentValues类来创建一个包含当前时间的数据行,并使用update方法将其更新到数据库中。在重置计时器时,我们使用insert方法向数据库中插入一个包含默认时间的数据行。
Android studio获取数据库表中时间
要获取数据库表中的时间,首先需要确定时间字段的数据类型。如果时间字段的数据类型是DATETIME或TIMESTAMP,则可以使用以下代码在Android Studio中获取时间:
```
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date date = dateFormat.parse(cursor.getString(cursor.getColumnIndex("time")));
```
其中,"time"是时间字段的名称,cursor是查询数据库返回的游标。这段代码将字符串形式的时间转换为Date类型,然后您就可以使用Date对象进行后续操作了。
相关推荐
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)