2015-06-15 4 views
2

Я писал приложение, чтобы читать частоту сердечных сокращений и количество шагов, используя устройство износа android. Датчик сердечного ритма работает правильно, но количество шагов вызывает проблему. Однако, комментируя слушателя для счетчика шагов и регистрируя нуль в onResume(), приложение работает с датчиком частоты сердечных сокращений. Я не получаю никакого журнала относительно этого, иначе я бы разместил его здесь. Вот код, который я используюAndroid Wear Step Counter crashing app

import android.app.Activity; 
import android.content.Context; 
import android.hardware.Sensor; 
import android.hardware.SensorEvent; 
import android.hardware.SensorEventListener; 
import android.hardware.SensorManager; 
import android.os.Bundle; 
import android.support.wearable.view.WatchViewStub; 
import android.util.Log; 
import android.widget.TextView; 

import com.google.android.gms.common.api.GoogleApiClient; 
import com.google.android.gms.common.api.PendingResult; 
import com.google.android.gms.common.api.ResultCallback; 
import com.google.android.gms.wearable.Node; 
import com.google.android.gms.wearable.NodeApi; 
import com.google.android.gms.wearable.Wearable; 

import java.nio.ByteBuffer; 
import java.util.List; 

public class MainActivity extends Activity { 

    private SensorManager mSensorManager; 
    private TextView mTextViewHeart, mTextViewStep; 
    private Sensor mHeartRateSensor, mStepCounterSensor; 
    private GoogleApiClient mGoogleApiClient; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 

     WatchViewStub stub = (WatchViewStub) findViewById(R.id.watch_view_stub); 
     stub.setOnLayoutInflatedListener(new WatchViewStub.OnLayoutInflatedListener() { 
      @Override 
      public void onLayoutInflated(WatchViewStub stub) { 
       mTextViewHeart = (TextView) stub.findViewById(R.id.value_heart); 
       mTextViewStep = (TextView) stub.findViewById(R.id.value_step); 
      } 
     }); 

     mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE); 
     mHeartRateSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_HEART_RATE); 
     mStepCounterSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_STEP_COUNTER); 

     mGoogleApiClient = new GoogleApiClient.Builder(this).addApi(Wearable.API).build(); 
     mGoogleApiClient.connect(); 
    } 

    @Override 
    protected void onResume() { 
     super.onResume(); 
     mSensorManager.registerListener(heartListener, mHeartRateSensor, SensorManager.SENSOR_DELAY_NORMAL); 
     mSensorManager.registerListener(stepListener, mStepCounterSensor, SensorManager.SENSOR_DELAY_FASTEST); 
    } 

    @Override 
    protected void onPause() { 
     super.onPause(); 
     mSensorManager.unregisterListener(heartListener, mHeartRateSensor); 
    } 

    SensorEventListener heartListener = new SensorEventListener() { 
     @Override 
     public void onSensorChanged(SensorEvent event) { 
      if (event.sensor.getType() == Sensor.TYPE_HEART_RATE) { 
       if (event.values.length > 0) { 
        if (event.values[0] > 0.0f) { 
         mTextViewHeart.setBackgroundResource(android.R.color.holo_green_light); 
         mTextViewHeart.setText(Float.toString(event.values[0])); 
         sendToHandheld(Math.round(event.values[0]), Sensor.TYPE_HEART_RATE); 
        } 
       } 
      } 
     } 

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

     } 
    }; 

    SensorEventListener stepListener = new SensorEventListener() { 
     @Override 
     public void onSensorChanged(SensorEvent event) { 

      if (event.sensor.getType() == Sensor.TYPE_STEP_COUNTER) { 
       if (event.values.length > 0) { 
        mTextViewStep.setBackgroundResource(android.R.color.holo_green_light); 
        mTextViewStep.setText(Float.toString(event.values[0])); 
        sendToHandheld(Math.round(event.values[0]), Sensor.TYPE_STEP_COUNTER); 
       } 
      } 
     } 

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

     } 
    }; 

    private void sendToHandheld(final int val, final int type) { 
     final PendingResult<NodeApi.GetConnectedNodesResult> nodes = Wearable.NodeApi.getConnectedNodes(mGoogleApiClient); 
     nodes.setResultCallback(new ResultCallback<NodeApi.GetConnectedNodesResult>() { 
      @Override 
      public void onResult(NodeApi.GetConnectedNodesResult result) { 
       final List<Node> nodes = result.getNodes(); 
       if (nodes != null) { 
        for (int i = 0; i < nodes.size(); i++) { 
         final Node node = nodes.get(i); 
         Wearable.MessageApi.sendMessage(mGoogleApiClient, node.getId(), "/" + type, ByteBuffer.allocate(4).putInt(val).array()); 
         Log.d("Sending", type + ":" + val); 
        } 
       } 
      } 
     }); 
    } 
} 

Update

Got журнал как-то

06-15 11:46:02.342 3355-3355/com.hsc.fit E/AndroidRuntime﹕ FATAL EXCEPTION: main 
    Process: com.hsc.fit, PID: 3355 
    java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setBackgroundResource(int)' on a null object reference 
      at com.hsc.fit.MainActivity$3.onSensorChanged(MainActivity.java:92) 
      at android.hardware.SystemSensorManager$SensorEventQueue.dispatchSensorEvent(SystemSensorManager.java:405) 
      at android.os.MessageQueue.nativePollOnce(Native Method) 
      at android.os.MessageQueue.next(MessageQueue.java:143) 
      at android.os.Looper.loop(Looper.java:122) 
      at android.app.ActivityThread.main(ActivityThread.java:5221) 
      at java.lang.reflect.Method.invoke(Native Method) 
      at java.lang.reflect.Method.invoke(Method.java:372) 
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) 
+0

Я не уверен в этом, но интересовался этим кодом. Итак, немного погуглил, вы можете проверить эти ссылки и сравнить с вашим кодом. Одна из ссылок содержит код для ведения журнала. http://marctan.com/blog/2014/07/08/reading-heart-rate-data-from-samsung-gear-live/ https://gist.github.com/mjohnsullivan/557c2f19ba177312b1d7 –

+0

@gansai, спасибо для ссылок. Я уже видел первый. Во втором случае код в основном выполняет то же, что и мой код, но проблема в том, что приложение терпит крах, поэтому код журнала не работает. Кроме того, я тоже не получаю журнал сбоев, что затрудняет отладку. –

+0

Похоже, что mTextViewStep иногда становится недействительным (не знаю почему), и из-за этого, когда данные датчика меняются, когда вы хотите установить mTextViewStep со своими значениями, он выдает это исключение. Предложение: вы можете зарегистрировать предупреждение, если mTextViewStep равно null, добавив проверку и если mTextViewStep не имеет значения null, установите значения. Это может временно избежать сбой приложения –

ответ

0

Fixed его. WatchViewStubsetOnLayoutInflatedListener() вызывается после onResume(), а мой датчик регистрируется в onResume(). Поскольку мое текстовое представление используется в прослушивателе датчика, и еще не было присвоено refrence, я получал NullPointerException. Я переместил регистрацию датчика внутри слушателя WatchViewStub, и он работает сейчас.