Я хочу разработать приложение для Android с тремя действиями и двумя службами.
Первая служба с именем WebClientService вызывает REST API каждые 30 секунд, используя обработчик, и должна уведомить активное действие о результате. Он также должен уведомить вторую службу с именем DatabaseService, чтобы обновить локальную БД.
Служба базы данных будет вызываться только один раз onCreate действия (в случае сбоя и перезапуска приложения) и только один раз при onRestart (таким образом у нас есть данные для отображения в если были проблемы с подключением). Затем действия будут обновляться благодаря службе WebClientService, которая уведомляет об «активных» действиях каждые 30 секунд.
Вопросы:
Каков наилучший способ уведомить об обновлении как активной активности, так и фоновой службы базы данных? Моя идея состоит в том, чтобы использовать sendBroadcast() в WebClientService и BroadcastReceiver в каждом действии и в пределах DatabaseService, это правильный подход?
Должен ли я использовать тот же подход для связи между AllMeetingRoomActivity и DatabaseService или должен использовать Bound Служба?
Спасибо
ОБНОВЛЕНИЕ: DatabaseService больше не будет фоновой службой, а будет просто общим экземпляром уровня базы данных между WebClientService и действиями.
Итак, теперь возникает вопрос: является ли хорошим подходом просто записывать мои 30-секундные обновления в локальную базу данных и разрешать действиям обновлять себя каждые несколько секунд, просто читая из локальной базы данных? Не слишком ли это повлияет на производительность?
Контекст:
Следует тому, что я реализовал до сих пор, но с использованием SettableFutures, и поэтому его необходимо повторно реализовать с помощью Services и Broadcasts, как только я пойму, как заставить их эффективно взаимодействовать:
public class MainActivity extends AppCompatActivity {
private TextView meetingsTextView;
private EditText mEdit, editSubject;
private final ConnectorInitializer clientInitializer = new ConnectorInitializer();
private AppConnector genericClient; // can use OutlookClient or a test client to talk with a mock server
@Override
protected void onCreate(Bundle savedInstanceState) {
// initializes client based on the settings in "config.json"
genericClient = clientInitializer.create(this);
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
meetingsTextView = (TextView) findViewById(R.id.NowMeeting);
mEdit = (EditText)findViewById(R.id.editText);
editSubject = (EditText)findViewById(R.id.editSubject);
Futures.addCallback(genericClient.logon(this, scopes), new FutureCallback<Boolean>() {
@Override
public void onSuccess(Boolean result) {
Log.d("APP", "-- Logged in. --");
databaseConnector.synchronouslyGetBackupFromLocalDatabase() // FUTURE
// callback here
// onSuccess, onFailure
}
@Override
public void onFailure(@NonNull Throwable t) {
Log.e("\n ~~~~>> logon \n", t.getMessage());
meetingsTextView.setText(R.string.Login_Failed);
}
});
}
/** At the moment the UI is not updated automatically every 30 seconds
* but manually using a refresh button
*/
public void getBookings(@SuppressWarnings("UnusedParameters") View view){
Log.d("APP", "Retrieve button clicked: "+(DateTime.now())+". Calling async getCalendar.");
meetingsTextView.setText(R.string.retrieving_events);
try{
Futures.addCallback( genericClient.getCalendarEvents(), new FutureCallback<String>(){
@Override
public void onSuccess(final String resultCalendars) {
Log.d("APP", "Success. Result: "+resultCalendars);
runOnUiThread(new Runnable() {
@Override
public void run() {
Log.d("APP", "Calendars SUCCESSFULLY retrieved.");
String meetingsRetrieved = getString(R.string.calendar)+resultCalendars;
meetingsTextView.setText(meetingsRetrieved);
Toast.makeText(getApplicationContext(), "Success!", Toast.LENGTH_LONG).show();
}
});
databaseConnector.asyncUpdateLocalDbWithResults(); // FUTURE
// callback here
// onSuccess, onFailure
}
@Override
public void onFailure(@NonNull Throwable t) {
Log.e( "APP", "Calendar error. Cause: "+t.getLocalizedMessage() );
String retrieveError = "Retrieve error. \n\n\n"+t.getLocalizedMessage();
meetingsTextView.setText(retrieveError);
Toast.makeText(getApplicationContext(), "Fail!", Toast.LENGTH_LONG).show();
}
});
}catch(Exception ex){
Log.e("APP","Something went wrong in your code. Cause:"+ex);
}
}