Android ProgressDialog 卡在 onResponse 中
Android ProgressDialog is stuck in onResponse
我正在使用 Volley 库在 Android 中创建一个应用程序,我想将 ProgressDialog 添加到 loadAll()
方法的 onResponse()
,但是当我这样做时,轮子不会' 在方法中移动。
我曾尝试为 onResponse
和 ProgressDialog 本身使用 AsyncTask,但它甚至不会出现。如果有人能帮我解决这个问题,那真的很有帮助。
这里是 loadAll()
方法:
public void loadAll() {
checkPermissions();
String tag_string_req = "string_req";
final String TAG = AppController.class
.getSimpleName();
String url = "http://android.diggin.io/projectmanager/v1/all";
pDialog = new ProgressDialog(this);
pDialog.setMessage("Synchronizing...");
pDialog.show();
StringRequest strReq = new StringRequest(Request.Method.GET,
url, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.d(TAG, response);
try {
JSONObject jsonObject = new JSONObject(response);
if (!jsonObject.getBoolean("error")) {
SharedPreferences sharedPref = MainActivity.this.getSharedPreferences(getString(R.string.user_id), Context.MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPref.edit();
editor.putInt(getString(R.string.user_id), jsonObject.getInt("user_id"));
editor.commit();
JSONArray jsonProjects = jsonObject.getJSONArray("projects");
JSONArray jsonPhotos = jsonObject.getJSONArray("photos");
db.clearDB();
File dir = getDir("projectImages", Context.MODE_PRIVATE);
if (dir.isDirectory()) {
String[] children = dir.list();
for (int count = 0; count < children.length; count++)
{
boolean onlyThumbs = true;
File subDir = new File(dir, children[count]);
String[] subChildren = subDir.list();
for (int count2 = 0; count2 < subChildren.length; count2++)
{
File subSubDir = new File(subDir, subChildren[count2]);
String[] subSubChildren = subSubDir.list();
for (int count3 = 0; count3 < subSubChildren.length; count3++)
{
if (subSubChildren[count3].startsWith("picture")) {
onlyThumbs = false;
}
}
if (onlyThumbs) {
File file = new File(subSubDir.getPath());
if (file.exists()) {
String deleteCmd = "rm -r " + subSubDir.getPath();
Runtime runtime = Runtime.getRuntime();
try {
runtime.exec(deleteCmd);
} catch (IOException e) {
Log.e("IOException",e.toString());
}
}
}
}
if (onlyThumbs) {
File file = new File(subDir.getPath());
if (file.exists()) {
String deleteCmd = "rm -r " + subDir.getPath();
Runtime runtime = Runtime.getRuntime();
try {
runtime.exec(deleteCmd);
} catch (IOException e) {
Log.e("IOException",e.toString());
}
}
}
}
}
for (int i = 0; i < jsonProjects.length(); i++) {
JSONObject jsonProject = (JSONObject) jsonProjects.get(i);
Project project = new Project(jsonProject.getInt("id"),jsonProject.getString("title"),jsonProject.getInt("user_id"));
db.addProject(project);
JSONArray jsonWells = jsonProject.getJSONArray("wells");
for (int i2 = 0; i2 < jsonWells.length(); i2++)
{
JSONObject jsonWell = (JSONObject) jsonWells.get(i2);
Well well = new Well(jsonWell.getInt("id"),jsonWell.getString("number"),jsonWell.getInt("project_id"));
db.addWell(well);
}
JSONArray jsonTracks = jsonProject.getJSONArray("tracks");
for (int i2 = 0; i2 < jsonTracks.length(); i2++)
{
JSONObject jsonTrack = (JSONObject) jsonTracks.get(i2);
Track track = new Track(jsonTrack.getInt("id"),jsonTrack.getString("number"));
boolean inDb = false;
for (Track t : db.getAllTracks()) {
if(t.toString().equals(track.toString())) {
inDb = true;
}
}
if (!inDb) {
db.addTrack(track);
}
Track_Well track_well = new Track_Well(db.getAllTrackWells().size() + 1, jsonTrack.getInt("id"), jsonTrack.getInt("well_id"));
db.addTrackWell(track_well);
}
JSONArray jsonSurfaces = jsonProject.getJSONArray("surfaces");
for (int i2 = 0; i2 < jsonSurfaces.length(); i2++)
{
JSONObject jsonSurface = (JSONObject) jsonSurfaces.get(i2);
Surface surface = new Surface(jsonSurface.getInt("id"),jsonSurface.getString("number"),jsonSurface.getInt("well_id"));
boolean inDb = false;
for (Surface s : db.getAllSurfaces()) {
if(s.toString().equals(surface.toString())) {
inDb = true;
}
}
if (!inDb) {
db.addSurface(surface);
}
Track_Surface track_surface = new Track_Surface(db.getAllTrackSurfaces().size() + 1, (!jsonSurface.isNull("track_id") ? jsonSurface.getInt("track_id") : 0), jsonSurface.getInt("id"));
db.addTrackSurface(track_surface);
}
JSONArray jsonProfiles = jsonProject.getJSONArray("profiles");
for (int i2 = 0; i2 < jsonProfiles.length(); i2++)
{
JSONObject jsonProfile = (JSONObject) jsonProfiles.get(i2);
Profile profile = new Profile(jsonProfile.getInt("id"),jsonProfile.getString("number"),jsonProfile.getInt("well_id"));
boolean inDb = false;
for (Profile p : db.getAllProfiles()) {
if(p.toString().equals(profile.toString())) {
inDb = true;
}
}
if (!inDb) {
db.addProfile(profile);
}
Track_Profile track_profile = new Track_Profile(db.getAllTrackProfiles().size() + 1, (!jsonProfile.isNull("track_id") ? jsonProfile.getInt("track_id") : 0), jsonProfile.getInt("id"));
db.addTrackProfile(track_profile);
}
JSONArray jsonFieldfinds = jsonProject.getJSONArray("fieldfinds");
for (int i2 = 0; i2 < jsonFieldfinds.length(); i2++)
{
JSONObject jsonFieldfind = (JSONObject) jsonFieldfinds.get(i2);
Fieldfind fieldfind = new FieldfindBuilder().id(jsonFieldfind.getInt("id"))
.number(jsonFieldfind.getString("number"))
.project_id(!jsonFieldfind.isNull("project_id") ? jsonFieldfind.getInt("project_id") : 0) // if (!jsonFieldfind.isNull("project_id")) {
.well_id(!jsonFieldfind.isNull("well_id") ? jsonFieldfind.getInt("well_id") : 0) // well_id = jsonFieldfind.getInt("project_id");
.track_id(!jsonFieldfind.isNull("track_id") ? jsonFieldfind.getInt("track_id") : 0) // } else {
.surface_id(!jsonFieldfind.isNull("surface_id") ? jsonFieldfind.getInt("surface_id") : 0) // well_id = 0;
.profile_id(!jsonFieldfind.isNull("profile_id") ? jsonFieldfind.getInt("profile_id") : 0) // }
.user_id(jsonFieldfind.getInt("user_id")).buildFieldfind();
db.addFieldfind(fieldfind);
}
}
for(int i3 = 0; i3 < jsonPhotos.length(); i3++) {
JSONObject jsonPhoto = (JSONObject) jsonPhotos.get(i3);
File mainDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES) + File.separator + "ProjectManager");
String pathStart = mainDir.getPath() + "/";
Photo photo = new Photo(jsonPhoto.getInt("id"), jsonPhoto.getInt("user_id"), jsonPhoto.getString("imageable_type"), jsonPhoto.getInt("imageable_id"), pathStart + jsonPhoto.getString("image_path"),jsonPhoto.getString("description"),jsonPhoto.getString("metadata"),jsonPhoto.getString("wind"));
Log.d("LoadAll - Photos(" + i3 + ")", photo.toString());
String filename = photo.getDBImage_path();
File pictureFile = new File(mainDir, filename);
photo.setImage_path(pictureFile.toString());
if (!pictureFile.exists()) {
photo.setImage_path(photo.getThumbnailFromImage_path());
db.addPhoto(photo);
String image_str = jsonPhoto.getString("image");
byte[] byte_arr = Base64.decode(image_str, 0);
Bitmap bitmap = BitmapFactory.decodeByteArray(byte_arr, 0, byte_arr.length);
try {
createPicture(bitmap, photo);
} catch (IOException e) {
e.printStackTrace();
}
} else {
db.addPhoto(photo);
syncPhotos.add(photo);
}
}
getAllProjects();
} else {
//Send message when username and/or password is incorrect
runOnUiThread(new Runnable() {
@Override
public void run() {
AlertDialog.Builder dlgAlert = new AlertDialog.Builder(MainActivity.this);
dlgAlert.setMessage("Something went wrong");
dlgAlert.setPositiveButton("OK", null);
dlgAlert.setCancelable(true);
dlgAlert.create().show();
}
});
Intent intent = new Intent(MainActivity.this, LoginActivity.class);
startActivity(intent);
}
} catch (JSONException e) {
e.printStackTrace();
}
pDialog.hide();
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
VolleyLog.d(TAG, "Error: " + error.getMessage());
pDialog.hide();
}
}) {
//Passing some request headers
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
HashMap<String, String> headers = new HashMap<>();
headers.put("Authorization", apiKey);
return headers;
}
};
// Adding request to request queue
AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
}
检查您的代码,您似乎在主线程上执行数据库操作,这可能是进度对话框挂起的原因。
在后台线程中移动数据库操作(使用 AsyncTask),这样就可以了。
我正在使用 Volley 库在 Android 中创建一个应用程序,我想将 ProgressDialog 添加到 loadAll()
方法的 onResponse()
,但是当我这样做时,轮子不会' 在方法中移动。
我曾尝试为 onResponse
和 ProgressDialog 本身使用 AsyncTask,但它甚至不会出现。如果有人能帮我解决这个问题,那真的很有帮助。
这里是 loadAll()
方法:
public void loadAll() {
checkPermissions();
String tag_string_req = "string_req";
final String TAG = AppController.class
.getSimpleName();
String url = "http://android.diggin.io/projectmanager/v1/all";
pDialog = new ProgressDialog(this);
pDialog.setMessage("Synchronizing...");
pDialog.show();
StringRequest strReq = new StringRequest(Request.Method.GET,
url, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.d(TAG, response);
try {
JSONObject jsonObject = new JSONObject(response);
if (!jsonObject.getBoolean("error")) {
SharedPreferences sharedPref = MainActivity.this.getSharedPreferences(getString(R.string.user_id), Context.MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPref.edit();
editor.putInt(getString(R.string.user_id), jsonObject.getInt("user_id"));
editor.commit();
JSONArray jsonProjects = jsonObject.getJSONArray("projects");
JSONArray jsonPhotos = jsonObject.getJSONArray("photos");
db.clearDB();
File dir = getDir("projectImages", Context.MODE_PRIVATE);
if (dir.isDirectory()) {
String[] children = dir.list();
for (int count = 0; count < children.length; count++)
{
boolean onlyThumbs = true;
File subDir = new File(dir, children[count]);
String[] subChildren = subDir.list();
for (int count2 = 0; count2 < subChildren.length; count2++)
{
File subSubDir = new File(subDir, subChildren[count2]);
String[] subSubChildren = subSubDir.list();
for (int count3 = 0; count3 < subSubChildren.length; count3++)
{
if (subSubChildren[count3].startsWith("picture")) {
onlyThumbs = false;
}
}
if (onlyThumbs) {
File file = new File(subSubDir.getPath());
if (file.exists()) {
String deleteCmd = "rm -r " + subSubDir.getPath();
Runtime runtime = Runtime.getRuntime();
try {
runtime.exec(deleteCmd);
} catch (IOException e) {
Log.e("IOException",e.toString());
}
}
}
}
if (onlyThumbs) {
File file = new File(subDir.getPath());
if (file.exists()) {
String deleteCmd = "rm -r " + subDir.getPath();
Runtime runtime = Runtime.getRuntime();
try {
runtime.exec(deleteCmd);
} catch (IOException e) {
Log.e("IOException",e.toString());
}
}
}
}
}
for (int i = 0; i < jsonProjects.length(); i++) {
JSONObject jsonProject = (JSONObject) jsonProjects.get(i);
Project project = new Project(jsonProject.getInt("id"),jsonProject.getString("title"),jsonProject.getInt("user_id"));
db.addProject(project);
JSONArray jsonWells = jsonProject.getJSONArray("wells");
for (int i2 = 0; i2 < jsonWells.length(); i2++)
{
JSONObject jsonWell = (JSONObject) jsonWells.get(i2);
Well well = new Well(jsonWell.getInt("id"),jsonWell.getString("number"),jsonWell.getInt("project_id"));
db.addWell(well);
}
JSONArray jsonTracks = jsonProject.getJSONArray("tracks");
for (int i2 = 0; i2 < jsonTracks.length(); i2++)
{
JSONObject jsonTrack = (JSONObject) jsonTracks.get(i2);
Track track = new Track(jsonTrack.getInt("id"),jsonTrack.getString("number"));
boolean inDb = false;
for (Track t : db.getAllTracks()) {
if(t.toString().equals(track.toString())) {
inDb = true;
}
}
if (!inDb) {
db.addTrack(track);
}
Track_Well track_well = new Track_Well(db.getAllTrackWells().size() + 1, jsonTrack.getInt("id"), jsonTrack.getInt("well_id"));
db.addTrackWell(track_well);
}
JSONArray jsonSurfaces = jsonProject.getJSONArray("surfaces");
for (int i2 = 0; i2 < jsonSurfaces.length(); i2++)
{
JSONObject jsonSurface = (JSONObject) jsonSurfaces.get(i2);
Surface surface = new Surface(jsonSurface.getInt("id"),jsonSurface.getString("number"),jsonSurface.getInt("well_id"));
boolean inDb = false;
for (Surface s : db.getAllSurfaces()) {
if(s.toString().equals(surface.toString())) {
inDb = true;
}
}
if (!inDb) {
db.addSurface(surface);
}
Track_Surface track_surface = new Track_Surface(db.getAllTrackSurfaces().size() + 1, (!jsonSurface.isNull("track_id") ? jsonSurface.getInt("track_id") : 0), jsonSurface.getInt("id"));
db.addTrackSurface(track_surface);
}
JSONArray jsonProfiles = jsonProject.getJSONArray("profiles");
for (int i2 = 0; i2 < jsonProfiles.length(); i2++)
{
JSONObject jsonProfile = (JSONObject) jsonProfiles.get(i2);
Profile profile = new Profile(jsonProfile.getInt("id"),jsonProfile.getString("number"),jsonProfile.getInt("well_id"));
boolean inDb = false;
for (Profile p : db.getAllProfiles()) {
if(p.toString().equals(profile.toString())) {
inDb = true;
}
}
if (!inDb) {
db.addProfile(profile);
}
Track_Profile track_profile = new Track_Profile(db.getAllTrackProfiles().size() + 1, (!jsonProfile.isNull("track_id") ? jsonProfile.getInt("track_id") : 0), jsonProfile.getInt("id"));
db.addTrackProfile(track_profile);
}
JSONArray jsonFieldfinds = jsonProject.getJSONArray("fieldfinds");
for (int i2 = 0; i2 < jsonFieldfinds.length(); i2++)
{
JSONObject jsonFieldfind = (JSONObject) jsonFieldfinds.get(i2);
Fieldfind fieldfind = new FieldfindBuilder().id(jsonFieldfind.getInt("id"))
.number(jsonFieldfind.getString("number"))
.project_id(!jsonFieldfind.isNull("project_id") ? jsonFieldfind.getInt("project_id") : 0) // if (!jsonFieldfind.isNull("project_id")) {
.well_id(!jsonFieldfind.isNull("well_id") ? jsonFieldfind.getInt("well_id") : 0) // well_id = jsonFieldfind.getInt("project_id");
.track_id(!jsonFieldfind.isNull("track_id") ? jsonFieldfind.getInt("track_id") : 0) // } else {
.surface_id(!jsonFieldfind.isNull("surface_id") ? jsonFieldfind.getInt("surface_id") : 0) // well_id = 0;
.profile_id(!jsonFieldfind.isNull("profile_id") ? jsonFieldfind.getInt("profile_id") : 0) // }
.user_id(jsonFieldfind.getInt("user_id")).buildFieldfind();
db.addFieldfind(fieldfind);
}
}
for(int i3 = 0; i3 < jsonPhotos.length(); i3++) {
JSONObject jsonPhoto = (JSONObject) jsonPhotos.get(i3);
File mainDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES) + File.separator + "ProjectManager");
String pathStart = mainDir.getPath() + "/";
Photo photo = new Photo(jsonPhoto.getInt("id"), jsonPhoto.getInt("user_id"), jsonPhoto.getString("imageable_type"), jsonPhoto.getInt("imageable_id"), pathStart + jsonPhoto.getString("image_path"),jsonPhoto.getString("description"),jsonPhoto.getString("metadata"),jsonPhoto.getString("wind"));
Log.d("LoadAll - Photos(" + i3 + ")", photo.toString());
String filename = photo.getDBImage_path();
File pictureFile = new File(mainDir, filename);
photo.setImage_path(pictureFile.toString());
if (!pictureFile.exists()) {
photo.setImage_path(photo.getThumbnailFromImage_path());
db.addPhoto(photo);
String image_str = jsonPhoto.getString("image");
byte[] byte_arr = Base64.decode(image_str, 0);
Bitmap bitmap = BitmapFactory.decodeByteArray(byte_arr, 0, byte_arr.length);
try {
createPicture(bitmap, photo);
} catch (IOException e) {
e.printStackTrace();
}
} else {
db.addPhoto(photo);
syncPhotos.add(photo);
}
}
getAllProjects();
} else {
//Send message when username and/or password is incorrect
runOnUiThread(new Runnable() {
@Override
public void run() {
AlertDialog.Builder dlgAlert = new AlertDialog.Builder(MainActivity.this);
dlgAlert.setMessage("Something went wrong");
dlgAlert.setPositiveButton("OK", null);
dlgAlert.setCancelable(true);
dlgAlert.create().show();
}
});
Intent intent = new Intent(MainActivity.this, LoginActivity.class);
startActivity(intent);
}
} catch (JSONException e) {
e.printStackTrace();
}
pDialog.hide();
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
VolleyLog.d(TAG, "Error: " + error.getMessage());
pDialog.hide();
}
}) {
//Passing some request headers
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
HashMap<String, String> headers = new HashMap<>();
headers.put("Authorization", apiKey);
return headers;
}
};
// Adding request to request queue
AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
}
检查您的代码,您似乎在主线程上执行数据库操作,这可能是进度对话框挂起的原因。 在后台线程中移动数据库操作(使用 AsyncTask),这样就可以了。