Android 将数据插入本地数据库时 ProgressBar 不更新
Android ProgressBar not update when insert data to local db
我在更新进度条时遇到问题。在这里,我制作了一个自定义进度条函数,如下所示
ProgressDialog progressBar1;
private int progressBarStatus = 0;
private void customProgressBar(){
progressBar1 = new ProgressDialog(DictionaryActivity.this);
progressBar1.setCancelable(true);
progressBar1.setMessage("Downloading File...");
progressBar1.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
progressBar1.setMax(100);
progressBar1.setProgress(0);
progressBar1.show();
//reset progress bar status
progressBarStatus = 0;
new Thread(new Runnable() {
public void run() {
while (progressBarStatus < 100) {
Log.d("TAG", "run: pStatus" + " " + pStatus);
try {
Thread.sleep(1000);
}
catch (InterruptedException e) {
e.printStackTrace();
}
// call progressBar status data update
progressBarStatus = setProgressBarStatus();
new Handler(Looper.getMainLooper()).post(new Runnable(){
@Override
public void run() {
progressBar1.setProgress(progressBarStatus);
Log.d("TAG", "run: handler: " +progressBarStatus);
}
});
}
// when, file is downloaded 100%,
if (progressBarStatus >= 100) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// close the progress bar dialog
progressBar1.dismiss();
}
}
}).start();
}
public int setProgressBarStatus(){
return progressBarStatus += 2;
}
然后从数据下载函数中调用它。数据下载完成后,我将数据插入 SQLite DB(本地 dB)。
这里是数据插入前进度条更新。但是当数据声明插入进度条时不更新。如何解决这个问题?
谢谢大家。
我已经解决了这个问题。经过 3 小时的研究,我发现当我在 Thread
中添加插入函数(从我调用 DB 进行插入的地方)并将更新的进度值发送到 Progress Thread
时。然后它完美地工作并且 setProgress()
更新了进度。
int pStatus = 0;
public void dataInsertinoUsingThread(final Example data){
new Thread(new Runnable() {
@Override
public void run() {
for (int i=0; i<data.getData().getBanglaWordDictionary().size(); i++){
.........
pStatus+=i;
}
}
}).start();
}
感谢大家。如果有人遇到此类问题。你可以按照这个方法。另外,如果有人找到比我的解决方案更好的解决方案,您可以给出您的答案或建议。
我在更新进度条时遇到问题。在这里,我制作了一个自定义进度条函数,如下所示
ProgressDialog progressBar1;
private int progressBarStatus = 0;
private void customProgressBar(){
progressBar1 = new ProgressDialog(DictionaryActivity.this);
progressBar1.setCancelable(true);
progressBar1.setMessage("Downloading File...");
progressBar1.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
progressBar1.setMax(100);
progressBar1.setProgress(0);
progressBar1.show();
//reset progress bar status
progressBarStatus = 0;
new Thread(new Runnable() {
public void run() {
while (progressBarStatus < 100) {
Log.d("TAG", "run: pStatus" + " " + pStatus);
try {
Thread.sleep(1000);
}
catch (InterruptedException e) {
e.printStackTrace();
}
// call progressBar status data update
progressBarStatus = setProgressBarStatus();
new Handler(Looper.getMainLooper()).post(new Runnable(){
@Override
public void run() {
progressBar1.setProgress(progressBarStatus);
Log.d("TAG", "run: handler: " +progressBarStatus);
}
});
}
// when, file is downloaded 100%,
if (progressBarStatus >= 100) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// close the progress bar dialog
progressBar1.dismiss();
}
}
}).start();
}
public int setProgressBarStatus(){
return progressBarStatus += 2;
}
然后从数据下载函数中调用它。数据下载完成后,我将数据插入 SQLite DB(本地 dB)。
这里是数据插入前进度条更新。但是当数据声明插入进度条时不更新。如何解决这个问题? 谢谢大家。
我已经解决了这个问题。经过 3 小时的研究,我发现当我在 Thread
中添加插入函数(从我调用 DB 进行插入的地方)并将更新的进度值发送到 Progress Thread
时。然后它完美地工作并且 setProgress()
更新了进度。
int pStatus = 0;
public void dataInsertinoUsingThread(final Example data){
new Thread(new Runnable() {
@Override
public void run() {
for (int i=0; i<data.getData().getBanglaWordDictionary().size(); i++){
.........
pStatus+=i;
}
}
}).start();
}
感谢大家。如果有人遇到此类问题。你可以按照这个方法。另外,如果有人找到比我的解决方案更好的解决方案,您可以给出您的答案或建议。