package edu.vanderbilt.cs282.feisele; import android.app.Activity; import android.content.ComponentName; import android.content.Context; import android.content.Intent; import android.content.ServiceConnection; import android.os.Bundle; import android.os.IBinder; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.Toast; public class LifecycleLoggingServiceActivities { /** * <p> * Example of explicitly starting and stopping the local service. This * demonstrates the implementation of a service that runs in the same * process as the rest of the application, which is explicitly started and * stopped as desired. * </p> * * <p> * Note that this is implemented as an inner class only keep the sample all * together; typically this code would appear in some separate class. * <p> * Watch for button clicks. */ public static class Controller extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.lifecycle_service_controller); final Button startButton = (Button) findViewById(R.id.start); startButton.setOnClickListener(mStartListener); final Button stopButton = (Button) findViewById(R.id.stop); stopButton.setOnClickListener(mStopListener); } /** * Make sure the service is started. It will continue running until * someone calls stopService(). The Intent we use to find the service * explicitly specifies our service component, because we want it * running in our own process and don't want other applications to * replace it. */ private OnClickListener mStartListener = new OnClickListener() { public void onClick(View v) { startService(new Intent(Controller.this, LifecycleLoggingService.class)); } }; private OnClickListener mStopListener = new OnClickListener() { public void onClick(View v) { // Cancel a previous call to startService(). Note that the // service will not actually stop at this point if there are // still bound clients. stopService(new Intent(Controller.this, LifecycleLoggingService.class)); } }; } // ---------------------------------------------------------------------- /** * Example of binding and unbinding to the local service. This demonstrates * the implementation of a service which the client will bind to, receiving * an object through which it can communicate with the service.</p> * * <p> * Note that this is implemented as an inner class only keep the sample all * together; typically this code would appear in some separate class. */ public static class Binding extends Activity { private boolean mIsBound; @SuppressWarnings("unused") private LifecycleLoggingService mBoundService; private ServiceConnection mConnection = new ServiceConnection() { /** * This is called when the connection with the service has been * established, giving us the service object we can use to interact * with the service. Because we have bound to a explicit service * that we know is running in our own process, we can cast its * IBinder to a concrete class and directly access it. */ public void onServiceConnected(ComponentName className, IBinder service) { mBoundService = ((LifecycleLoggingService.LocalBinder) service) .getService(); Toast.makeText(Binding.this, R.string.local_service_connected, Toast.LENGTH_SHORT).show(); } /** * This is called when the connection with the service has been * unexpectedly disconnected -- that is, its process crashed. * Because it is running in our same process, we should never see * this happen. */ public void onServiceDisconnected(ComponentName className) { mBoundService = null; Toast.makeText(Binding.this, R.string.local_service_disconnected, Toast.LENGTH_SHORT) .show(); } }; /** * Establish a connection with the service. We use an explicit class * name because we want a specific service implementation that we know * will be running in our own process (and thus won't be supporting * component replacement by other applications). */ void doBindService() { bindService( new Intent(Binding.this, LifecycleLoggingService.class), mConnection, Context.BIND_AUTO_CREATE); mIsBound = true; } void doUnbindService() { if (mIsBound) { // Detach our existing connection. unbindService(mConnection); mIsBound = false; } } @Override protected void onDestroy() { super.onDestroy(); doUnbindService(); } private OnClickListener mBindListener = new OnClickListener() { public void onClick(View v) { doBindService(); } }; private OnClickListener mUnbindListener = new OnClickListener() { public void onClick(View v) { doUnbindService(); } }; /** * Watch for button clicks. * * @param savedInstanceState */ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.lifecycle_service_binding); final Button bindButton = (Button) findViewById(R.id.bind); bindButton.setOnClickListener(mBindListener); final Button unbindButton = (Button) findViewById(R.id.unbind); unbindButton.setOnClickListener(mUnbindListener); } } }