使用alarmManager和服务从服务器获取数据反复(Use alarmManager and s

2019-10-20 02:37发布

我的问题是要验证每两小时才得知有数据库中的新数据,我创建这个用户界面:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >

        <EditText
            android:id="@+id/speedAlert"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:ems="10"
            android:gravity="center"
            android:hint="km/h"
            android:inputType="number" />

        <CheckBox
            android:id="@+id/checkBoxSpeed"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

<Button
    android:id="@+id/btnConfirmSpeed"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="Confirm" />

因此,当用户输入的EditText的值,并选中复选框,并确认通过点击该按钮,创建一个报警,并每两小时,在该报警器启动服务:

btnConfirmSpeed.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {

            cal = Calendar.getInstance();
            triggerAtTime = cal.getTimeInMillis()+ (1 * 30 * 60 * 1000); // starts in 30 minutes
            repeat_alarm_every = (2 * 60 * 60 * 1000); // repeat every 2 hour
            int _id = (int) System.currentTimeMillis();
            Intent intent = new Intent(Alarm.this, NotificaSpeed.class);
            //get the value of checkbox from sharedpreferences
                    boolean tgpref = pref.getBoolean("checkVitessePref", false); 
            String sp = speedAlert.getText().toString();
            if(checkBoxSpeed.isChecked()){
                if(sp.matches(""))
                    Toast.makeText(getApplicationContext(), "specify speed", Toast.LENGTH_SHORT).show();
                else 
                {
                    editor = pref.edit();
                    editor.putBoolean("checkVitessePref", true); // value to store
                    editor.putInt("speedalarm", Integer.parseInt(speedAlert.getText().toString()));
                    editor.commit();

                    pintent = PendingIntent.getService(Alarm.this, _id, intent, 0);
                    alarm = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
                    alarm.setRepeating(AlarmManager.RTC_WAKEUP, triggerAtTime, repeat_alarm_every, pintent);


                } 
            }else {

                alarm.cancel(pintent);
                editor.putBoolean("checkVitessePref", false); // value to store
                editor.commit();
                stopService(new Intent(Alarm.this,NotificaSpeed.class));
            }

        }
    });

该NotificaSpeed是服务:

public class NotificaSpeed extends Service{

@Override
public IBinder onBind(Intent intent) {
    // TODO Auto-generated method stub
    return null;
}
@Override
public void onCreate() {

    mNotificationManager = (NotificationManager) getSystemService(ns);
    super.onCreate();
}

@Override
public void onDestroy() {
    super.onDestroy();
}

@Override
public int onStartCommand(Intent intent, int flags, int startId) {

    new VerifySpeedCar().execute();
    return super.onStartCommand(intent, flags, startId);
}

public void notification(int carsNumber, int speed){
    NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(NotificaSpeed.this);
    if(carsNumber != 0)

        notificationBuilder.setContentTitle(carsNumber+" cars are exceeding the speed");

                        .setSmallIcon(R.drawable.ic_launcher)
                        .setAutoCancel(true);
    final int _idI = (int) System.currentTimeMillis();
    Intent notificationIntent = new Intent(NotificaSpeed.this, ListCars.class);
    PendingIntent contentIntent = PendingIntent.getActivity(this, _idI, notificationIntent, 0);
    notificationBuilder.setContentIntent(contentIntent);

    notificationBuilder.setDefaults(Notification.DEFAULT_SOUND | Notification.DEFAULT_LIGHTS | Notification.DEFAULT_VIBRATE);

    mNotificationManager.notify(SIMPLE_NOTIFICATION_ID, notificationBuilder.build());

}

class VerifySpeedCar extends AsyncTask<String, String, String> {

protected String doInBackground(String... args) {
    // Building Parameters
    List<NameValuePair> params = new ArrayList<NameValuePair>();
    params.add(new BasicNameValuePair(TAG_ACCOUNTID, accountID));
    params.add(new BasicNameValuePair(TAG_SPEEDKPH, ""+speedpref)); // how can I get the value of edittext of the speed from the sharedpreferences?

        JSONObject json = jParser.makeHttpRequest(url, "GET", params);
        try {
            int success = json.getInt(TAG_SUCCESS);
            if (success == 1) {
                cars = json.getJSONArray(TAG_CARS);
                carsNumber = cars.length();
            } else 
                carsNumber = 0;

        } catch (JSONException e) {
            e.printStackTrace();
        }
    }

    return null;
}
protected void onPostExecute(String file_url) {
  if( carsNumber != 0){
      notification(carsNumber, speedpref);
  }
}}}

首先是做验证或我做错了是好办法吗? 第二我怎样才能从sharedpreferences的EditText上的价值? 最后当我关闭应用程序的服务太采空,所以当我再次启动应用程序的服务不再运行,但复选框的值仍然选中,我怎样才能解决这个问题?

感谢您抽出时间来阅读我的问题的时间。 任何帮助将不胜感激

Answer 1:

如何获得的EditText从SharedPreference价值?

创建SharedPreference和SharedPreference.Editor对象。

 SharedPreferences sp ;
 sp = this.getSharedPreferences("YOUR PREF NAME", 0);

我相信你都可以从EditText上的字符串str像值

str = ed.getText().toString();
SharedPreferences.Editor editor = sp.edit();
editor.putString("edit_text", str);
editor.commit();

从检索的SharedPreference价值的EditText

如果您检索在同一个活动,则

String value = sp.getString("edit_text", null);

如果在不同的活动,则第一个实例这样的SharedPreference

SharedPreference sp = this.getSharedPreferences("YOUR PREF NAME", 0);


文章来源: Use alarmManager and service to get data from server repeatedly