Galaxy Nexus: очень медленные показания датчиков - PullRequest
0 голосов
/ 23 марта 2012

У меня действительно странная проблема на моем Samsung Galaxy Nexus - я пытаюсь считывать значения некоторых датчиков, например, с гироскопа.Очень простой код, просто слушатель датчика, помещающий значение в список после простой интеграции с течением времени.

Когда я запускаю код на Nexus S в течение примерно 60 секунд, я могу зарегистрировать около 60 000 событий датчика (SENSOR_DELAY_FASTEST) но если я запустил его на Galaxy Nexus, я получу только около 6000 значений за 60 секунд.

Есть ли способ увеличить это?Мне действительно нужно больше данных датчика для того, что я делаю, и кроме устройства, единственное отличие - версия ОС: 4.0.2 на Galaxy Nexus - 4.0.3 на Nexus S.

Любой советбудет признателен!

Редактировать - код:

SensorManager sm = (SensorManager) getSystemService(SENSOR_SERVICE);
LogSensorEventListener listener = new LogSensorEventListener(
       SensorLoggerActivity.this, Sensor.TYPE_GYROSCOPE);
sm.registerListener(listener, sm.getDefaultSensor(Sensor.TYPE_GYROSCOPE),
       SensorManager.SENSOR_DELAY_FASTEST);

LogSensorEventListener также является очень простой реализацией SensorEventListenerInterface:

@Override
public void onSensorChanged(SensorEvent event) {

    final float dT = (event.timestamp - mTimestamp) / 1000000000.f;
    if (dT < 1) { // just a fix for the first step

        mRelZ += event.values[2] * dT;
        list.add(mRelZ);
        list2.add(event.timestamp);
    }
    mTimestamp = event.timestamp;

mRelZ изначально установлен в 0и два списка должны отслеживать время и измеренное значение.По окончании измерения (щелкнув по кнопке) значения записываются в файл:

    try {

        for (int i = 0; i < list.size(); i++) {

            long time = list2.get(i);

            if (mStartTime < 0) {
                mStartTime = time;
                time = 0;
            } else {
                time = time - mStartTime;
            }

            float timef = time / 1000000000.0f;
            sb.append(timef);
            sb.append(";");
            sb.append(Math.toDegrees(list.get(i)));
            sb.append("\n");
        }

        mOutFileStream.write(sb.toString().getBytes());

        mOutFileStream.flush();
        mOutFileStream.close();
    } catch (IOException e) {
    }

1 Ответ

0 голосов
/ 24 марта 2012

Устройства Android не имеют стандартов того, как и когда они сообщают об изменениях датчика. Например, некоторые устройства не будут сообщать об изменениях, если нет изменений (например, устройство движется). Некоторые устройства сообщают о множестве изменений, а другие - о меньших изменениях, даже если вы используете задержку, например, SensorManager.SENSOR_DELAY_FASTEST.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...