Én próbál végrehajtani a visszahívási Android Java JsonObjectRequests. Azt találtuk, tucatnyi üzenetét mutatja kód, amely csaknem szó szerint. A problémám az, hogy a callbacknull. Lásd a két belső észrevételeit.
public interface JsonObjectCallbackInterface {
void onSuccess(JSONObject result);
}
class DispatchBuddyBase {
//...
public void addGmapMarker(String inAddress) {
final String address = DBB.prepareAddress(inAddress);
DatabaseReference ref = DBB.getTopPathRef(/geocodedAddresses);
ref.orderByChild(address)
.equalTo(address)
.addListenerForSingleValueEvent(
new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
Log.i(TAG, address+ stored: +dataSnapshot.exists());
if (!dataSnapshot.exists()) {
DBB.getLatLng(
17 River Rd Meriden CT 06451,
new JsonObjectCallbackInterface() {
// ^--- why is this passing a **null?**
@Override
public void onSuccess(JSONObject response) {
Log.i(TAG, got a json body:+response.toString());
addGmapMarker(response);
}
});
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
}
public class DispatchesActivity extends AppCompatActivity implements
OnMapReadyCallback,
GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener,
ResultCallback<LocationSettingsResult> {
//...
public void getLatLng(final String address,
final JsonObjectCallbackInterface callback) {
// why does this get a **null** callback? -------------^
Log.e(TAG, callback is: +callback);
String url = https://maps.googleapis.com/maps/api/geocode/json?address=
+ address;
JsonObjectRequest jsObjRequest = new JsonObjectRequest
(Request.Method.GET, url, null, new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
Log.e(TAG,Response: + response.toString());
DatabaseReference ref = getTopPathRef(/geocodedAddresses).push();
Map<String, Object> u = new HashMap<>();
u.put(address, address);
u.put(geocoded, response.toString());
ref.updateChildren(u, new DatabaseReference.CompletionListener() {
@Override
public void onComplete(DatabaseError databaseError,
DatabaseReference databaseReference) {
if (databaseError != null) {
Log.e(TAG,Geocoded address could not be saved
+ databaseError.getMessage());
} else {
Log.e(TAG,Geocoded address saved successfully.);
}
}
});
Log.e(TAG, callback2 is: +callback);
callback.onSuccess(response);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
// TODO Auto-generated method stub
}
});
DBVolley.getInstance(context)
.addToRequestQueue(jsObjRequest);
}
}
Ahhoz, hogy tiszta, én egyszer megjegyezni, hogy callbacknem volt null csak egyszer , amikor én tesztelés. Ismételje fut nem termelt nem üres visszahívás azóta. Én csak 8 nappal a Java, ezért kérjük, bocsánat, ha tettem valamit naiv.
A DispatchBuddyBaseSingleton instanszolt a fő tevékenység csak egyszer, és DBVolleyhasonlóképpen. Minden további referenciákat kap ugyanolyan keresztül DispatchBuddyBase.getInstance(). Még nem volt semmilyen probléma névtelen osztályok máshol.
A Volley kód csupasz csont és kilőtt kérelmeket csak finom, a JsonObjectRequest sikeresen megkap mindent, amit elvár a Google. Minden más működik dagad kivéve ezt visszahívás.
Mit kell kijavítani, hogy helyesen adja át ezt a visszahívási?













