2016-08-15 4 views
0

UPDATE: Я добавил всю MainService AND MainActivity, если в другом месте что-то не так. Кроме того, я также добавил решение, представленное ниже, хотя оно по-прежнему не будет обновлять TextView.SharedPreferences не работает при попытке обновить TextView

Я пытаюсь изменить TextView, и я хочу, чтобы он был постоянным, поэтому я использую SharedPreferences. К сожалению, что-то не так, потому что TextView не обновляется.

MainService:

public class MainService extends Service { 

public static final String BROADCAST_ACTION = "com.example.vladpintea.friendsbeforecents.displayevent"; 
private final Handler handler = new Handler(); 
int counterr = 0; 
Intent intentt; 

String usedTimer; 
long interval; 

//TimerTask that will cause the run() runnable to happen. 
TimerTask myTask = new TimerTask() { 
    public void run() { 
     stopSelf(); 
    } 
}; 
//Timer that will make the runnable run. 
Timer myTimer = new Timer(); 

@Override 
public void onCreate() { 
    intentt = new Intent(BROADCAST_ACTION); 

    registerReceiver(counter, new IntentFilter(Intent.ACTION_SCREEN_ON)); 

    Toast.makeText(MainService.this, "Service, Created", Toast.LENGTH_SHORT).show(); 
} 

private BroadcastReceiver counter = new BroadcastReceiver() { 
    @Override 
    public void onReceive(Context context, Intent intent) { 
     Toast.makeText(MainService.this, "Whoops! You've Lost.", Toast.LENGTH_SHORT).show(); 
     Settings.System.putInt(getContentResolver(), Settings.System.SCREEN_OFF_TIMEOUT, 30000); 
    } 
}; 

@Override 
public int onStartCommand(Intent intent, int flags, int startId) { 
    Toast.makeText(MainService.this, "Service, Started", Toast.LENGTH_SHORT).show(); 

    usedTimer = intent.getStringExtra("timer"); 
    try { 
     interval = Long.parseLong(usedTimer); 
    } catch (NumberFormatException ignored) {} 

    myTimer.schedule(myTask, interval); 

    handler.removeCallbacks(sendUpdatesToUI); 
    handler.postDelayed(sendUpdatesToUI, 1000); 

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

private Runnable sendUpdatesToUI = new Runnable() { 
    public void run() { 
     handler.postDelayed(this, 1000); 
    } 
}; 

public void DisplayLoggingInfoPlus() { 
    intentt.putExtra("counter", String.valueOf(++counterr)); 
    sendBroadcast(intentt); 
} 

@Override 
public void onDestroy() { 
    DisplayLoggingInfoPlus(); 

    PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); 
    PowerManager.WakeLock wakeLock = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK 
      | PowerManager.ACQUIRE_CAUSES_WAKEUP 
      | PowerManager.ON_AFTER_RELEASE, "MyWakeLock"); 
    wakeLock.acquire(); 

    Settings.System.putInt(getContentResolver(), Settings.System.SCREEN_OFF_TIMEOUT, 30000); 
} 

@Override 
public IBinder onBind(Intent intent) { 
    return null; 
} 

MainActivity:

public class MainActivity extends AppCompatActivity { 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    final Button startApp = (Button) findViewById(R.id.startApp); 
    final EditText timer = (EditText) findViewById(R.id.insertTimer); 

    assert startApp != null; 
    startApp.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      Toast.makeText(MainActivity.this, "Countdown, Started", Toast.LENGTH_SHORT).show(); 

      Intent intent = new Intent(MainActivity.this, MainService.class); 

      assert timer != null; 
      intent.putExtra("timer", timer.getText().toString()); 

      Settings.System.putInt(getContentResolver(), Settings.System.SCREEN_OFF_TIMEOUT, 1000); 

      registerReceiver(broadcastReceiver, new IntentFilter(MainService.BROADCAST_ACTION)); 

      startService(intent); 
     } 
    }); 
} 

private BroadcastReceiver broadcastReceiver = new BroadcastReceiver() { 
    @Override 
    public void onReceive(Context context, Intent intent) { 
     updateUI(intent); 
    } 
}; 

private void updateUI(Intent intent) { 
    String counter = intent.getStringExtra("counter"); 
    TextView txtCounter = (TextView) findViewById(R.id.txtCounter); 
    assert txtCounter != null; 

    SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this); 
    SharedPreferences.Editor editor = preferences.edit(); 
    editor.putString(counter,txtCounter.getText().toString()); 
    editor.commit(); 
} 

}

+0

Возможный дубликат [Как использовать SharedPreferences в Android хранить, получать и редактировать значения] (http://stackoverflow.com/questions/3624280/how-to-use-sharedpreferences-in-android-to-store-fetch-and-edit-values) – piotrek1543

+0

asnswer указан в ссылке выше. Вы сохраняете значение, но не извлекаете – piotrek1543

ответ

0

К сожалению, что-то не так, потому что TextView не обновляется.

Вам необходимо обновить TextView по телефону SetText():

String counter = intent.getStringExtra("counter"); 
TextView txtCounter = (TextView) findViewById(R.id.txtCounter); 
txtCounter.setText(counter); 
0

Изменить следующую строку

от

editor.putString(String.valueOf(txtCounter), counter); 

в

editor.putString("counter",txtCounter.getText().toString()); 
+0

В txtCounter.getText() Я получаю сообщение об ошибке, говоря, что это неправильный тип аргумента. –

+0

добавил toString() – gaara87

+0

Все еще не повезло. Ошибок нет, он просто не обновится. –

0

Для хранения значений в общих настройках:

SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this); 
SharedPreferences.Editor editor = preferences.edit(); 
editor.putString("Counter",String.valueOf(txtCounter)); 
editor.apply(); 

Для извлечения значений из общих предпочтений:

SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this); 
String Counter= preferences.getString("Counter", ""); 
if(!Counter.equalsIgnoreCase("")) 
{ 
    Counter= Counter+ " Counter"; /* Edit the value here*/ 
} 
Смежные вопросы