开发者

Can't get service object (onServiceConnected never called)

I try to write a XML-log for phonestates on android. First i wrote a a single class to log things while the activity is active. Now i tried to write the xml-file in a service an bind the service to the activity. Later i want to log the states in background, so i will need at least one service and a broadcast reciever. But i fail at the binding and can't get a service object back at the onServiceConnected() - method. The method is never called. I tried to wait for the asynchronous start up of the service, like i read in another post, but it didn't work. I work with eclipse and the normal debugger.

public class MyActivity extends Activity {
//The layout of the application.
private TableLayout t;
//The service, which is writing the xml-file.
private FileService fservice;
private boolean mIsBound;
private final Handler handler = new Handler(); 

private ServiceConnection mConnection = new ServiceConnection() {
    public void onServiceConnected(ComponentName className, IBinder service) {
        // 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.
        fservice = ((FileService.LocalBinder)service).getService();

    }

    public void onServiceDisc开发者_Python百科onnected(ComponentName className) {
        // 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.
        fservice = null;
    }
};

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.table_layout);

    doBindService();

    //Initialization of the TableLayout. 
    t = (TableLayout) findViewById(R.id.myTableLayout);
}

@Override
public void onStart(){
    super.onStart();

    //Initialization of the TelephonyManager.
    final TelephonyManager myTelephonyMgr = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);

    Runnable r = new Runnable()
    {
            public void run()
            {
                //Gets the IMSI and IMEI.
                String imsi = myTelephonyMgr.getSubscriberId();
                createRow(getTimeStamp(), "IMSI: "+imsi);
                createLine();
                String imei = myTelephonyMgr.getDeviceId();
                createRow(getTimeStamp(), "IMEI: "+imei);
                createLine();

                //Gets the cell informations.
                GsmCellLocation cell = (GsmCellLocation) myTelephonyMgr.getCellLocation();
                createRow(getTimeStamp(),"CID: "+cell.getCid());
                createLine();
                createRow(getTimeStamp(), "LAC: "+cell.getLac());
                createLine();

                //Gets the call states.
                myTelephonyMgr.listen(new MyPhoneStateListener(MyActivity.this), PhoneStateListener.LISTEN_CALL_STATE);
            }
    };

    handler.postDelayed(r, 4000);


}

/**
 * Creates a new TableRow.
 * 
 * @param stampText
 * @param actionText
 */
protected void createRow(String stampText, String actionText){
    ...
    fservice.createRow(stampText, actionText);
}

...


private void doBindService() {
    // 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).
    bindService(new Intent(MyActivity.this, FileService.class), mConnection, Context.BIND_AUTO_CREATE);
    mIsBound = true;
}

private void doUnbindService() {
    if (mIsBound) {
        // Detach our existing connection.
        unbindService(mConnection);
        mIsBound = false;
    }
}


@Override
protected void onDestroy() {
    super.onDestroy();
    doUnbindService();
} 

}

public class FileService extends Service{ ... // This is the object that receives interactions from clients. private final IBinder mBinder = new LocalBinder();

/**
 * Class for clients to access.  Because we know this service always
 * runs in the same process as its clients, we don't need to deal with
 * IPC.
 */
public class LocalBinder extends Binder {
    FileService getService() {
        return FileService.this;
    }
}

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

}
...

}


Did you add the Service definition to the AndroidManifest.xml file? Like so:

<manifest ... >
  ...
  <application ... >
      <service android:name=".ExampleService" />
      ...
  </application>
</manifest>
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜