as can tell question topic, when run program on emulator works on first time, when run again without changes, shows "(project name) has stop working.
i don't know how fix this, tried cleaning project, building apk again, still there no solution.
any please, appreciated.
this code:
public class mainactivity extends appcompatactivity { locationmanager locationmanager; locationlistener locationlistener; textview latitude; textview longitude; textview accuracy; textview altitude; textview address; @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); latitude = (textview) findviewbyid(r.id.latitude); longitude = (textview) findviewbyid(r.id.longitude); accuracy = (textview) findviewbyid(r.id.accuracy); altitude = (textview) findviewbyid(r.id.altitude); locationmanager = (locationmanager) this.getsystemservice(context.location_service); // check if have location access permission if (contextcompat.checkselfpermission(this, manifest.permission.access_fine_location) != packagemanager.permission_granted) { // mean don't have permissions, need ask it. activitycompat.requestpermissions(this, new string[]{manifest.permission.access_fine_location}, 1); // 1 here sort of id identify request, called request code } else { // have permission // 0 , 0 mean keep track of user location changes, can change every 10 seconds or that. locationmanager.requestlocationupdates(locationmanager.gps_provider, 0, 0, locationlistener); } locationlistener = new locationlistener() { @override public void onlocationchanged(location location) { latitude.settext("latitude: " + location.getlatitude()); longitude.settext("longitude: " + location.getlongitude()); accuracy.settext("accuracy: " + location.getaccuracy()); altitude.settext("alitiude: " + location.getaltitude()); } @override public void onstatuschanged(string provider, int status, bundle extras) { } @override public void onproviderenabled(string provider) { } @override public void onproviderdisabled(string provider) { } }; } @override // controls dialog asks user location access permission public void onrequestpermissionsresult(int requestcode, @nonnull string[] permissions, @nonnull int[] grantresults) { super.onrequestpermissionsresult(requestcode, permissions, grantresults); // check if user clicked on dialog , choose allow. if (grantresults.length > 0 && grantresults[0] == packagemanager.permission_granted) { // if have permission, update user location. need check make code run! if (contextcompat.checkselfpermission(this, manifest.permission.access_fine_location) == packagemanager.permission_granted) { // 0 , 0 mean keep track of user location changes, can change every 10 seconds or that. locationmanager.requestlocationupdates(locationmanager.gps_provider, 0, 0, locationlistener); } } } }
even when copy code , put in new project, works again, same problem when run again doesnt work.
i got error
09-10 21:35:37.936 2588-2588/com.example.qubayel.test2 e/androidruntime: fatal exception: main process: com.example.qubayel.test2, pid: 2588 java.lang.runtimeexception: unable start activity componentinfo{com.example.qubayel.test2/com.example.qubayel.test2.mainactivity}: java.lang.illegalargumentexception: invalid listener: null @ android.app.activitythread.performlaunchactivity(activitythread.java:2665) @ android.app.activitythread.handlelaunchactivity(activitythread.java:2726) @ android.app.activitythread.-wrap12(activitythread.java) @ android.app.activitythread$h.handlemessage(activitythread.java:1477) @ android.os.handler.dispatchmessage(handler.java:102) @ android.os.looper.loop(looper.java:154) @ android.app.activitythread.main(activitythread.java:6119) @ java.lang.reflect.method.invoke(native method) @ com.android.internal.os.zygoteinit$methodandargscaller.run(zygoteinit.java:886) @ com.android.internal.os.zygoteinit.main(zygoteinit.java:776)
i found solution, problem i'm using locationlistener before defining it. on line of code:
// 0 , 0 mean keep track of user location changes, can change every 10 seconds or that. locationmanager.requestlocationupdates(locationmanager.gps_provider, 0, 0, locationlistener);
this definition should've been on top of locationlistener call:
locationlistener = new locationlistener() { @override public void onlocationchanged(location location) { latitude.settext("latitude: " + location.getlatitude()); longitude.settext("longitude: " + location.getlongitude()); accuracy.settext("accuracy: " + location.getaccuracy()); altitude.settext("alitiude: " + location.getaltitude()); } @override public void onstatuschanged(string provider, int status, bundle extras) { } @override public void onproviderenabled(string provider) { } @override public void onproviderdisabled(string provider) { } };
final code should this:
public class mainactivity extends appcompatactivity { locationmanager locationmanager; locationlistener locationlistener; textview latitude; textview longitude; textview accuracy; textview altitude; textview address; @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); latitude = (textview) findviewbyid(r.id.latitude); longitude = (textview) findviewbyid(r.id.longitude); accuracy = (textview) findviewbyid(r.id.accuracy); altitude = (textview) findviewbyid(r.id.altitude); locationmanager = (locationmanager) this.getsystemservice(context.location_service); locationlistener = new locationlistener() { @override public void onlocationchanged(location location) { latitude.settext("latitude: " + location.getlatitude()); longitude.settext("longitude: " + location.getlongitude()); accuracy.settext("accuracy: " + location.getaccuracy()); altitude.settext("alitiude: " + location.getaltitude()); } @override public void onstatuschanged(string provider, int status, bundle extras) { } @override public void onproviderenabled(string provider) { } @override public void onproviderdisabled(string provider) { } }; // check if have location access permission if (contextcompat.checkselfpermission(this, manifest.permission.access_fine_location) != packagemanager.permission_granted) { // mean don't have permissions, need ask it. activitycompat.requestpermissions(this, new string[]{manifest.permission.access_fine_location}, 1); // 1 here sort of id identify request, called request code } else { // have permission // 0 , 0 mean keep track of user location changes, can change every 10 seconds or that. locationmanager.requestlocationupdates(locationmanager.gps_provider, 0, 0, locationlistener); } } @override // controls dialog asks user location access permission public void onrequestpermissionsresult(int requestcode, @nonnull string[] permissions, @nonnull int[] grantresults) { super.onrequestpermissionsresult(requestcode, permissions, grantresults); // check if user clicked on dialog , choose allow. if (grantresults.length > 0 && grantresults[0] == packagemanager.permission_granted) { // if have permission, update user location. need check make code run! if (contextcompat.checkselfpermission(this, manifest.permission.access_fine_location) == packagemanager.permission_granted) { // 0 , 0 mean keep track of user location changes, can change every 10 seconds or that. locationmanager.requestlocationupdates(locationmanager.gps_provider, 0, 0, locationlistener); } } } }
Comments
Post a Comment