I 활동에 작동하는 작업 응용 프로그램이있다 -는 전화 수신기에서 GPS 데이터를 호출하고이안드로이드 GPS 서비스
final Handler handler = new Handler();
final Runnable runnable = new Runnable() {
public void run() {
if(indikator != 0)
{
Cursor c=db.rawQuery("select * from lokacije", null);
c.moveToLast();
try{
w.loadUrl(c.getString(c.getColumnIndex("lokacija")));
db.execSQL("delete from lokacije where id <"+c.getString(c.getColumnIndex("id")));
}
catch (Exception e) {
// TODO: handle exception
}
}
indikator=1;
handler.postDelayed(this, 90000);
}
};
//b.setBackgroundColor(Color.RED);
b.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
if(b.getText().equals("SLOBODAN"))
{
b.setText("ZAUZET");
b.setTextColor(Color.GREEN);
}
else
{
b.setText("SLOBODAN");
b.setTextColor(Color.RED);
}
}
});
//deo koji naknadno ubacujem za kriterijum
Criteria criteria = new Criteria();
criteria.setAccuracy(Criteria.ACCURACY_FINE);
criteria.setPowerRequirement(Criteria.POWER_LOW);
//kraj dela koji sam naknadno ubacio
final LocationManager m=(LocationManager) MainActivity.this.getSystemService(Context.LOCATION_SERVICE);
//deo koji sam takodje ubacio naknadno
String locationprovider =m.getBestProvider(criteria,true);
//deo koji sam takodje ubacio naknadno kraj
LocationListener l=new LocationListener() {
@Override
public void onStatusChanged(String arg0, int arg1, Bundle arg2) {
// TODO Auto-generated method stub
}
@Override
public void onProviderEnabled(String arg0) {
// TODO Auto-generated method stub
}
@Override
public void onProviderDisabled(String arg0) {
// TODO Auto-generated method stub
}
@Override
public void onLocationChanged(Location arg0) {
String url=new String();
String zauzetost=new String();
zauzetost=b.getText().toString();
String format="MM/dd/yyyy";
SimpleDateFormat sdf = new SimpleDateFormat(format,Locale.US);
String date= sdf.format(new Date());
t.setToNow();
ed1.setText("");
ed2.setText("");
String longitude=new String();
String latitude=new String();
String speed=new String();
if((int)arg0.getSpeed()==0)
{
speed="0";
}
else
{
speed=""+(((int)arg0.getSpeed()*3600)/1000);
}
longitude=""+ arg0.getLongitude();
latitude=""+ arg0.getLatitude();
ed1.setText(longitude);
ed2.setText(latitude);
ed3.setText(speed);
Calendar cal=Calendar.getInstance();
url="http://www.compensatemeonline.com/truckmeonline/TruckMeOnline/UnosLokacijaSaTelefona.php?id="+mojsadrzaj+"&longitude="+longitude+"&latitude="+latitude+"&brzina="+speed+"&vreme="+cal.getTime()+"&datum="+date+"&zauzetost="+zauzetost;
db.execSQL("insert into lokacije (lokacija) values ('"+url+"');");
// TODO Auto-generated method stub
}
};
// TODO Auto-generated method stub
//pozivanje threada
runnable.run();
//pozivanje threada
m.requestLocationUpdates(locationprovider, 60000, 0, l);
// zamenio sam m.requestLocationUpdates(LocationManager.GPS_PROVIDER, 120000, 0, l); sa m.requestLocationUpdates(locationprovider, 120000, 0, l);
}
과 같은 sqlite가에서 스레드의 마지막 위치를 필터링 내 PHP 사이트로 전송
이제 내가하고 싶은 일은 모든 것을 서비스에 넣어 백그라운드에서 작동하도록하는 것입니다. onCreate()
또는 onStart()
메서드에 Service
코드를 넣어야합니까? 핸들러와 다른 스레드를 사용하기 때문입니다. 내가 Activity
에로 WebView
를 사용할 수 없기 때문에 내가 URL 또는 HttpClient를 함께 이제 웹 사이트를 호출 할 때이처럼 내 로그 캣 내 실수를 제공합니다 내가 할 수 있도록
02-12 22:24:32.569: E/AndroidRuntime(1204): java.lang.IllegalStateException: Target host must not be null, or set in parameters. scheme=null, host=null, path=2
02-12 22:24:32.569: E/AndroidRuntime(1204): at org.apache.http.impl.client.DefaultRequestDirector.determineRoute(DefaultRequestDirector.java:591)
02-12 22:24:32.569: E/AndroidRuntime(1204): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:293)
02-12 22:24:32.569: E/AndroidRuntime(1204): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
02-12 22:24:32.569: E/AndroidRuntime(1204): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
02-12 22:24:32.569: E/AndroidRuntime(1204): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
02-12 22:24:32.569: E/AndroidRuntime(1204): at com.example.serviceswithactivity.MyService$1.run(MyService.java:127)
02-12 22:24:32.569: E/AndroidRuntime(1204): at android.os.Handler.handleCallback(Handler.java:725)
02-12 22:24:32.569: E/AndroidRuntime(1204): at android.os.Handler.dispatchMessage(Handler.java:92)
02-12 22:24:32.569: E/AndroidRuntime(1204): at android.os.Looper.loop(Looper.java:137)
02-12 22:24:32.569: E/AndroidRuntime(1204): at android.app.ActivityThread.main(ActivityThread.java:5039)
02-12 22:24:32.569: E/AndroidRuntime(1204): at java.lang.reflect.Method.invokeNative(Native Method)
02-12 22:24:32.569: E/AndroidRuntime(1204): at java.lang.reflect.Method.invoke(Method.java:511)
02-12 22:24:32.569: E/AndroidRuntime(1204): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
02-12 22:24:32.569: E/AndroidRuntime(1204): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
02-12 22:24:32.569: E/AndroidRuntime(1204): at dalvik.system.NativeStart.main(Native Method)
가 어떻게 서비스에서 GPS 위치를 부르죠 10-15 점이 아니라 단 한 점을 얻으시겠습니까? 나는 Activity에서 sqlite 데이터베이스에 데이터를 넣고 나중에 스레드의 마지막 행을 가져 와서 원에서 다른 행을 삭제하는 등의 작업을 수행했습니다. GPS 위치를 호출하고 백그라운드에서 웹 사이트로 전송하는 더 좋은 방법이 있습니까?
이것은 내 Service
전체 :
public class MyService extends Service {
public int indikator=0;
public String mojsadrzaj=new String();
public String pib=new String();
public String username=new String();
public String password=new String();
public Cursor c;
public Cursor d;
URL myURL;
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
}
@Override
public void onCreate() {
super.onCreate();
Toast.makeText(this,"Service created ...",Toast.LENGTH_LONG).show();
final SQLiteDatabase db=openOrCreateDatabase("TruckMe", MODE_PRIVATE, null);
db.execSQL("create table if not exists lokacije (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, lokacija VARCHAR(600));");
//regulisanje podataka za logovanje samo prvi put
String idvozaca=new String();
db.execSQL("create table if not exists vozac (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, idvozaca VARCHAR(15));");
d=db.rawQuery("select idvozaca from vozac", null);
//db.execSQL("delete from vozac;");
if(d.getCount() > 0)
{
d.moveToLast();
idvozaca=d.getString(d.getColumnIndex("idvozaca"));
mojsadrzaj=idvozaca;
Toast t=Toast.makeText(this, "Id vozaca je : " + mojsadrzaj, Toast.LENGTH_LONG);
t.setGravity(Gravity.CENTER, 0, 0);
t.show();
}
else
{
//ubacivanje forme za dijalog
//unos vozacid u bazu
db.execSQL("insert into vozac (idvozaca) values ('"+mojsadrzaj+"');");
//unos vozacid u bazu
//String resString = sb.toString(); // Result is here
Toast t=Toast.makeText(this, "Aplikacija je aktivirana sa kodom : "+mojsadrzaj, Toast.LENGTH_LONG);
t.setGravity(Gravity.CENTER, 0, 0);
t.show();
}
//regulisanje podataka za logovanje samo prvi put
final Time t=new Time();
//deo za thread
final Handler handler = new Handler();
final Runnable runnable = new Runnable() {
public void run() {
if(indikator != 0)
{
//w.loadUrl(c.getString(c.getColumnIndex("lokacija")));
final SQLiteDatabase db=openOrCreateDatabase("TruckMe", MODE_PRIVATE, null);
c=db.rawQuery("select * from lokacije", null);
c.moveToLast();
try {
HttpClient client=new DefaultHttpClient();
URI website=new URI(c.getString(c.getColumnIndex("id")));
Log.e("Message", website.toString());
HttpGet request=new HttpGet();
request.setURI(website);
try {
client.execute(request);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} catch (URISyntaxException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
/*
URL url = null;
try {
url = new URL(c.getString(c.getColumnIndex("id")));
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
URLConnection urlConnection = null;
try {
urlConnection = url.openConnection();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
urlConnection.connect();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
*/
/*
try {
myURL = new URL(c.getString(c.getColumnIndex("id")));
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
URLConnection myURLConnection = null;
try {
myURLConnection = myURL.openConnection();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
myURLConnection.connect();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
*/
db.execSQL("delete from lokacije where id <"+c.getString(c.getColumnIndex("id")));
// TODO: handle exception
}
indikator=1;
handler.postDelayed(this, 15000);
}
};
//deo koji naknadno ubacujem za kriterijum
Criteria criteria = new Criteria();
criteria.setAccuracy(Criteria.ACCURACY_FINE);
criteria.setPowerRequirement(Criteria.POWER_LOW);
//kraj dela koji sam naknadno ubacio
final LocationManager m=(LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
//deo koji sam takodje ubacio naknadno
String locationprovider =m.getBestProvider(criteria,true);
//deo koji sam takodje ubacio naknadno kraj
LocationListener l=new LocationListener() {
@Override
public void onStatusChanged(String arg0, int arg1, Bundle arg2) {
// TODO Auto-generated method stub
}
@Override
public void onProviderEnabled(String arg0) {
// TODO Auto-generated method stub
}
@Override
public void onProviderDisabled(String arg0) {
// TODO Auto-generated method stub
}
@Override
public void onLocationChanged(Location arg0) {
String url=new String();
String zauzetost=new String();
zauzetost="ZAUZET";
String format="MM/dd/yyyy";
SimpleDateFormat sdf = new SimpleDateFormat(format,Locale.US);
String date= sdf.format(new Date());
t.setToNow();
String longitude=new String();
String latitude=new String();
String speed=new String();
if((int)arg0.getSpeed()==0)
{
speed="0";
}
else
{
speed=""+(((int)arg0.getSpeed()*3600)/1000);
}
longitude=""+ arg0.getLongitude();
latitude=""+ arg0.getLatitude();
Calendar cal=Calendar.getInstance();
url="http://www.compensatemeonline.com/truckmeonline/TruckMeOnline/UnosLokacijaSaTelefona.php?id="+mojsadrzaj+"&longitude="+longitude+"&latitude="+latitude+"&brzina="+speed+"&vreme="+cal.getTime()+"&datum="+date+"&zauzetost="+zauzetost;
Toast.makeText(MyService.this, url,Toast.LENGTH_LONG).show();
db.execSQL("insert into lokacije (lokacija) values ('"+url+"');");
// TODO Auto-generated method stub
}
};
// TODO Auto-generated method stub
//pozivanje threada
runnable.run();
//pozivanje threada
m.requestLocationUpdates(locationprovider, 10000, 0, l);
// zamenio sam m.requestLocationUpdates(LocationManager.GPS_PROVIDER, 120000, 0, l); sa m.requestLocationUpdates(locationprovider, 120000, 0, l);
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Toast.makeText(this, "Service started onstartcommand ...",Toast.LENGTH_LONG).show();
return START_STICKY;
}
@Override
public void onStart(Intent intent, int startId) {
Toast.makeText(this, "Service started onstart...",Toast.LENGTH_LONG).show();
}
@Override
public void onDestroy() {
super.onDestroy();
Toast.makeText(this, "Service destroyed ...",Toast.LENGTH_LONG).show();
}
}
문제는 GPS 코드와 관련이 없습니다. 문제는 커서에서로드하려는 URL이 올바르지 않다는 것입니다. 'w.loadUrl'의 인수를 게시하십시오. – hwrdprkns
이것은 내가 웹 대신 w.loadurl –
의 서비스 http://www.compensatemeonline.com/truckmeonline/TruckMeOnline/UnosLokacijaSaTelefona.php?id="+mojsadrzaj+"&longitude="+longitude+"&latitude="+latitude+에서 사용하는 것입니다 "& brzina ="+ speed + "& vreme ="+ cal.getTime() + "& datum ="+ 날짜 + "& zauzetost ="+ zauzetost 이들은 브라우저에서 인쇄하여 사용하는 변수이며 결과는 –