Проблемы с SensorManager в WearOS

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

public class MainActivity extends WearableActivity implements SensorEventListener {



private SensorManager mSensorManager;
private Sensor mAcceSensor;
private final static String TAG = "Wear MainActivity";
private TextView mTextView;
private Button myButton;
private ToggleButton activateSensors;
private int num = 1;
public boolean isOn;
private String datapath = "/message_path";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main_activity);
    mTextView =  findViewById(R.id.text);

    //send a message from the wear.  This one will not have response.
    myButton =  findViewById(R.id.wrbutton);
    activateSensors = findViewById(R.id.toggleButton);
    activateSensors.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton compoundButton, boolean isChecked) {
            if (isChecked) isOn = true;
            else isOn = false;
        }
    });

    myButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            String message = "Hello device " + num;
            //Requires a new thread to avoid blocking the UI
            new SendThread(datapath, message).start();
            num++;
        }
    });

    // Register the local broadcast receiver to receive messages from the listener.
    IntentFilter messageFilter = new IntentFilter(Intent.ACTION_SEND);
    MessageReceiver messageReceiver = new MessageReceiver();
    LocalBroadcastManager.getInstance(this).registerReceiver(messageReceiver, messageFilter);

    mSensorManager = (SensorManager)getSystemService(Context.SENSOR_SERVICE);
    mAcceSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);

    // Enables Always-on
    setAmbientEnabled();
}

@Override
protected void onResume() {
    super.onResume();
    mSensorManager.registerListener(this, mAcceSensor,
            50000, 50000);
}

@Override
protected void onPause() {
    super.onPause();
    mSensorManager.unregisterListener(this, mAcceSensor);
}

@Override
public void onSensorChanged(SensorEvent sensorEvent) {
    if (sensorEvent.sensor.getType() == Sensor.TYPE_ACCELEROMETER){
        String msg = Float.toString(sensorEvent.values[0]) +","+ Float.toString(sensorEvent.values[1]) +","+ Float.toString(sensorEvent.values[2])+","+getCurrentTimeStamp();
        if (isOn){
                new SendThread(datapath, msg).start();
        }
    }
}

public static String getCurrentTimeStamp(){
    try {

        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String currentDateTime = dateFormat.format(new Date()); // Find todays date
        return currentDateTime;
    } catch (Exception e) {
        e.printStackTrace();

        return null;
    }
}

@Override
public void onAccuracyChanged(Sensor sensor, int i) {

}

(Now a block about sending from one device to the other)
}

Как видите, у меня прослушиватель определен как mSensorManager.registerListener (this, mAcceSensor, 50000, 50000);

Это должно давать мне актуализацию каждые 50 миллисекунд, но я получил намного больше.

0
0
274
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

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

mSensorManager.registerListener (this, mAcceSensor, 50000, 50000);

Неважно, используете ли вы

 mSensorManager.registerListener(this, mAcceSensor, SensorManager.SENSOR_DELAY_UI);

или mSensorManager.registerListener (это, mAcceSensor, SensorManager.SENSOR_DELAY_FASTEST);

или мой код, он всегда использует максимально возможную частоту дискретизации, около 100 Гц.

Galaxy Nexus: частота выборки сенсора становится выше, чем больше выборок сенсоров

Частота дискретизации сенсора Android не будет ниже 60 Гц

В конце концов, я выбрал неаккуратный путь:

@Override
public void onSensorChanged(SensorEvent sensorEvent) {
    nowDate = new Date();
    if (sensorEvent.sensor.getType() == Sensor.TYPE_ACCELEROMETER){
        String msg = Float.toString(sensorEvent.values[0]) +","+ Float.toString(sensorEvent.values[1]) +","+ Float.toString(sensorEvent.values[2]);
        if (isOn && (nowDate.getTime() -startDate.getTime()) >= 40){
                startDate = nowDate;
                String timeStamp = dateFormat.format(nowDate);
                msg = msg +","+timeStamp;
                new SendThread(datapath, msg).start();
        }
    }
}

Работает, не идеально, но работает достаточно хорошо. Кажется, что не имеет значения, какое значение я выберу в условии if, я пробовал 40, 50 и 60, и все они почти идеально получили 16-17 Гц. Я также пробовал перейти с SENSOR_DELAY_UI на SENSOR_DELAY_FASTEST, и я получаю те же результаты, стабильно 16-17 Гц, так что это не вопрос выбора.

Я надеюсь, что это поможет кому-то с той же проблемой, и если есть более стильный способ решения, я буду читать.

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