Запуск приложения, когда оно качается с помощью трансляции

Я хочу, чтобы, когда мое приложение находилось в фоновом режиме, и я встряхивал телефон, приложение запускалось и выходило на передний план!

Для достижения этого я использовал вещательный приемник следующим образом:

public class BootReceiver extends BroadcastReceiver {

        @Override
        public void onReceive(Context arg0, Intent arg1) {
            // TODO Auto-generated method stub
             mSensorManager = (SensorManager) arg0.getSystemService(arg0.SENSOR_SERVICE);
               mSensorManager.registerListener( mSensorIntentListener, mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), SensorManager.SENSOR_DELAY_NORMAL);
        }

    }

Я зарегистрировал это также следующим образом:

<receiver 

             android:name=".BootReceiver">
            <intent-filter>
                <action android:name="android.intent.action.BOOT_COMPLETED" />
                 <action android:name="android.intent.action.QUICKBOOT_POWERON" />
            </intent-filter>
    </receiver>

Теперь для события Shake я использую этот код, как показано ниже:

private final SensorEventListener mSensorIntentListener = new SensorEventListener() {

            public void onSensorChanged(SensorEvent se) {
              float x = se.values[0];
              float y = se.values[1];
              float z = se.values[2];
              mAccelLast = mAccelCurrent;
              mAccelCurrent = (float) Math.sqrt((double) (x*x + y*y + z*z));
              float delta = mAccelCurrent - mAccelLast;
              mAccel = mAccel * 0.9f + delta; // perform low-cut filter
              if (mAccel > 12) {
                     Toast.makeText(getApplicationContext(), "Device has shaken.", Toast.LENGTH_LONG).show();
                     Intent intent = new Intent(getApplicationContext(), MainActivity.class)
                                .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                            startActivity(intent);
              }

            }

            @Override
            public void onAccuracyChanged(Sensor arg0, int arg1) {
                // TODO Auto-generated method stub

            }


     };

Теперь, когда я пытаюсь запустить приложение, поставить его на задний план и встряхнуть, оно не работает!

Так в чем же логическая ошибка и как заставить мое приложение выйти на передний план на дрожание?

Еще одна вещь, я использую концепцию вложенных классов, поэтому все классы находятся в классе MainActivity!

код полный!:

package com.example.sensorlist;



public class MainActivity extends ActionBarActivity {
     TextView tv1=null;
     static File file = null;
     private String outputFile = null;
      private float mAccel; // acceleration apart from gravity
      private float mAccelCurrent; // current acceleration including gravity
      private float mAccelLast; // last acceleration including gravity
      Button play,stop,record;
      MediaRecorder myAudioRecorder;
       public SensorManager mSensorManager;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
         play=(Button)findViewById(R.id.button3);
          stop=(Button)findViewById(R.id.button2);
          record=(Button)findViewById(R.id.button);


         stop.setEnabled(false);
          play.setEnabled(false);

          final File path =
                Environment.getExternalStoragePublicDirectory
                (
                    //Environment.DIRECTORY_PICTURES
                    //Environment.DIRECTORY_DCIM
                    Environment.DIRECTORY_DCIM + "/Utkarshrecord/"
                );

            // Make sure the sound directory exists.
            if(!path.exists())
            {
                path.mkdirs();
            }

           try {
             file=  File.createTempFile("sound", ".3gp", path);

            myAudioRecorder=new MediaRecorder();
            myAudioRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
            myAudioRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
            myAudioRecorder.setOutputFile(file.getAbsolutePath());

        } catch (IOException e2) {
            // TODO Auto-generated catch block
            e2.printStackTrace();
        }





          mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
          myAudioRecorder.setAudioEncoder(MediaRecorder.OutputFormat.AMR_NB);

        if( mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER)!=null){
            Toast.makeText(getBaseContext(), "Yes it is there ", Toast.LENGTH_LONG).show();
        }else{
            Toast.makeText(getBaseContext(), "Sry no accelerometer", Toast.LENGTH_LONG).show();
        }
        mSensorManager.registerListener(mSensorListener, mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), SensorManager.SENSOR_DELAY_NORMAL);
        mAccel = 0.00f;
        mAccelCurrent = SensorManager.GRAVITY_EARTH;
        mAccelLast = SensorManager.GRAVITY_EARTH;
        record.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
                try {
                   myAudioRecorder.prepare();
                   myAudioRecorder.start();
                }

                catch (IllegalStateException e) {
                   // TODO Auto-generated catch block
                   e.printStackTrace();
                }

                catch (IOException e) {
                   // TODO Auto-generated catch block
                   e.printStackTrace();
                }

                record.setEnabled(false);
                stop.setEnabled(true);

                Toast.makeText(getApplicationContext(), "Recording started", Toast.LENGTH_LONG).show();
             }
          });
        stop.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) throws IllegalArgumentException,SecurityException,IllegalStateException {
                try{
                     myAudioRecorder.stop();
                    myAudioRecorder.release();
                    myAudioRecorder  = null;




                }catch(Exception e){
                    e.printStackTrace();
                }
                Toast.makeText(getApplicationContext(), "Audio recorded successfully",Toast.LENGTH_LONG).show();
                stop.setEnabled(false);
                play.setEnabled(true);
             }
          });
        play.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) throws IllegalArgumentException,SecurityException,IllegalStateException {
                MediaPlayer m = new MediaPlayer();

                try {
                   m.setDataSource(file.getAbsolutePath());
                   m.prepare();
                }

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



                m.start();
                Toast.makeText(getApplicationContext(), "Playing audio", Toast.LENGTH_LONG).show();
             }
          });

    }


     private final SensorEventListener mSensorListener = new SensorEventListener() {

            public void onSensorChanged(SensorEvent se) {
              float x = se.values[0];
              float y = se.values[1];
              float z = se.values[2];
              mAccelLast = mAccelCurrent;
              mAccelCurrent = (float) Math.sqrt((double) (x*x + y*y + z*z));
              float delta = mAccelCurrent - mAccelLast;
              mAccel = mAccel * 0.9f + delta; // perform low-cut filter
              if (mAccel > 12) {
                     Toast.makeText(getApplicationContext(), "Device has shaken.", Toast.LENGTH_LONG).show();
                    try {
                        myAudioRecorder.prepare();
                          myAudioRecorder.start();
                            record.setEnabled(false);
                            stop.setEnabled(true);

                    } catch (IllegalStateException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }

                       Toast.makeText(getBaseContext(), "recording has started", Toast.LENGTH_SHORT).show();

                }
            }

            @Override
            public void onAccuracyChanged(Sensor arg0, int arg1) {
                // TODO Auto-generated method stub

            }


     };
     private final SensorEventListener mSensorIntentListener = new SensorEventListener() {

            public void onSensorChanged(SensorEvent se) {
              float x = se.values[0];
              float y = se.values[1];
              float z = se.values[2];
              mAccelLast = mAccelCurrent;
              mAccelCurrent = (float) Math.sqrt((double) (x*x + y*y + z*z));
              float delta = mAccelCurrent - mAccelLast;
              mAccel = mAccel * 0.9f + delta; // perform low-cut filter
              if (mAccel > 12) {
                     Toast.makeText(getApplicationContext(), "Device has shaken.", Toast.LENGTH_LONG).show();
                     Intent intent = new Intent(getApplicationContext(), MainActivity.class)
                                .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                            startActivity(intent);
              }

            }

            @Override
            public void onAccuracyChanged(Sensor arg0, int arg1) {
                // TODO Auto-generated method stub

            }


     };

     @Override
      protected void onPause() {
        mSensorManager.unregisterListener(mSensorListener);
        super.onPause();
      }
     @Override
      protected void onResume() {
        super.onResume();
        mSensorManager.registerListener(mSensorListener, mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), SensorManager.SENSOR_DELAY_NORMAL);
      }
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
    public class ShakeRec extends Service{

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

        @Override
        public void onCreate() {
            // TODO Auto-generated method stub
            super.onCreate();


        }



        @Override
        public void onDestroy() {
            // TODO Auto-generated method stub
            super.onDestroy();

        }

        @Override
        public int onStartCommand(Intent intent, int flags, int startId) {
            // TODO Auto-generated method stub

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



    }

    public class BootReceiver extends BroadcastReceiver {

        @Override
        public void onReceive(Context arg0, Intent arg1) {
            // TODO Auto-generated method stub
             mSensorManager = (SensorManager) arg0.getSystemService(arg0.SENSOR_SERVICE);
               mSensorManager.registerListener( mSensorIntentListener, mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), SensorManager.SENSOR_DELAY_NORMAL);
        }

    }


}

2 ответа

Решение

Ваш <receiver> элемент не будет работать. Если вы посмотрите на LogCat при перезагрузке, вы увидите предупреждения или ошибки от Android, говорящие о том, что он не может найти ваш BootReceiver учебный класс. Зарегистрированный манифест получатель не может быть вложенным классом внутри действия.

Избавиться от <receiver> элемент. Избавляться от BootReceiver, Зарегистрируй свой SensorEventListener в onCreate() вашей деятельности. Пока ваш процесс работает (который может быть не очень длинным), и пока устройство включено, вы должны получать сенсорные события.

Для захвата сотрясений вы должны использовать постоянно включенные датчики низкой мощности, зарегистрированные в сервисе закрепления пробуждения. Чтобы охватить большое количество устройств, ваше приложение должно найти, какие из этих датчиков с низким энергопотреблением доступны в телефоне. А затем используйте лучшую комбинацию, сводя к минимуму расход заряда батареи. Вам также необходимо убедиться, что ваше приложение занесено в белый список для оптимизации заряда батареи, чтобы оно могло выжить в фоновом режиме.

Другие вопросы по тегам