2013-05-13 172 views
0

與我的朋友們,我們正在一個項目中工作,爲此我需要創建一個android應用程序。 (我指定,我是在java編程的初學者)。致命異常:主要android

所以開始我一直遵循一個很好的教程(http://www.buildcircuit.com/sensorgraph-using-android-amarino-and-arduino/) 它解釋瞭如何創建一個連接輸入您的Arduino(微控制器)和與amarino(藍牙),您的Arduino。

該程序檢索可變電壓的值並將其顯示在手機上。

但是我有麻煩,我的程序無法正常工作。當我上傳到我的手機上時,它顯示一個黑色窗口,顯示一條錯誤消息「不幸的是,SensorGraph2已停止」 我不知道我能做什麼。

這個SensorGrpah.java:

package edu.mit.media.hlt.sensorgraph; 
import android.app.Activity; 
    import android.content.BroadcastReceiver; 
    import android.content.Context; 
    import android.content.Intent; 
    import android.content.IntentFilter; 
    import android.os.Bundle; 
    import android.widget.TextView; 
    import at.abraxas.amarino.Amarino; 
    import at.abraxas.amarino.AmarinoIntent; 


public class SensorGraph extends Activity { 


    private static final String DEVICE_ADDRESS = "00:15:FF:F2:0F:A8"; 

    private GraphView mGraph; 
    private TextView mValueTV; 

    private ArduinoReceiver arduinoReceiver = new ArduinoReceiver(); 


    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 

     setContentView(R.layout.main); 


     mGraph = (GraphView)findViewById(R.id.graph); 
     mValueTV = (TextView) findViewById(R.id.value); 

     mGraph.setMaxValue(1024); 
    } 

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

     registerReceiver(arduinoReceiver, new IntentFilter(AmarinoIntent.ACTION_RECEIVED)); 


     Amarino.connect(this, DEVICE_ADDRESS); 
    } 


    @Override 
    protected void onStop() { 
     super.onStop(); 


     Amarino.disconnect(this, DEVICE_ADDRESS); 


     unregisterReceiver(arduinoReceiver); 
    } 



    public class ArduinoReceiver extends BroadcastReceiver { 

     @Override 
     public void onReceive(Context context, Intent intent) { 
      String data = null; 


      final int dataType = intent.getIntExtra(AmarinoIntent.EXTRA_DATA_TYPE, -1); 


      if (dataType == AmarinoIntent.STRING_EXTRA){ 
       data = intent.getStringExtra(AmarinoIntent.EXTRA_DATA); 

       if (data != null){ 
        mValueTV.setText(data); 
        try { 

         final int sensorReading = Integer.parseInt(data); 
         mGraph.addDataPoint(sensorReading); 
        } 
        catch (NumberFormatException e) { /* oh data was not an integer */ } 
       } 
      } 
     } 
    } 

} 

和main.xml中

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    > 
    <edu.mit.media.hlt.sensorgraph.GraphView 
     android:id="@+id/graph" 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:layout_weight="4" 
    /> 
    <TextView 
     android:id="@+id/value" 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:layout_weight="6" 
     android:text="@string/hello" 
     android:textSize="40sp" 
     android:gravity="center" 
     android:background="#fff" 
    /> 
</LinearLayout> 

,當我試圖把它上傳我的手機上的logcat的

05-14 00:30:56.640: E/AndroidRuntime(29568): FATAL EXCEPTION: main 
05-14 00:30:56.640: E/AndroidRuntime(29568): java.lang.NoClassDefFoundError: at.abraxas.amarino.Amarino 
05-14 00:30:56.640: E/AndroidRuntime(29568): at edu.mit.media.hlt.sensorgraph.SensorGraph.onStart(SensorGraph.java:71) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1167) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.Activity.performStart(Activity.java:5216) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2073) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2125) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.ActivityThread.access$600(ActivityThread.java:140) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1227) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.os.Handler.dispatchMessage(Handler.java:99) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.os.Looper.loop(Looper.java:137) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at android.app.ActivityThread.main(ActivityThread.java:4898) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at java.lang.reflect.Method.invokeNative(Native Method) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at java.lang.reflect.Method.invoke(Method.java:511) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773) 
05-14 00:30:56.640: E/AndroidRuntime(29568): at dalvik.system.NativeStart.main(Native Method) 

感謝您的幫助。

+1

顯然,包含「at.abraxas.amarino.Amarino」類的庫沒有正確包含到APK中。仔細檢查庫是否在'libs'文件夾中。 – SimonSays 2013-05-13 23:30:20

回答

0

這是一個很常見的問題,今天我有同樣的麻煩。我解決了它在項目中創建一個文件夾庫,並將AmarinoLibrary的jar添加到這個文件夾,而不是添加一個外部jar。在這之後一切正常。希望這可以幫助你:)。