2016-03-06 64 views
0

我在我的應用程序中有這個活動,其中當用戶點擊一個按鈕時,它將執行方法內的CameraUpdate。下面的代碼:無法執行android的方法:onClick

LocationsActivity.java

public class TermLocActivity extends AppCompatActivity implements OnMapReadyCallback { 

    GoogleMap map; 


    public static final CameraPosition MoloTerminal = 
      new CameraPosition.Builder().target(new LatLng(10.699160, 122.547208)) 
      .zoom(16) 
      .bearing(300) 
      .tilt(50) 
      .build(); 

    public static final CameraPosition TagbakTerminal = 
      new CameraPosition.Builder().target(new LatLng(10.761854, 122.577128)) 
        .zoom(16) 
        .bearing(300) 
        .tilt(50) 
        .build(); 

    public static final CameraPosition CeresTerminal = 
      new CameraPosition.Builder().target(new LatLng(10.758862, 122.567774)) 
        .zoom(16) 
        .bearing(300) 
        .tilt(50) 
        .build(); 


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

     SupportMapFragment mapFragment = 
       (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map); 
     mapFragment.getMapAsync(this); 


    } 

    @Override 
    public void onMapReady(GoogleMap map) { 

     map.addMarker(new MarkerOptions().position(new LatLng(10.699160, 122.547208)).title("San Pedro Molo Terminal")); 
     map.moveCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(10.699160, 122.547208), 16)); 
    } 


    public void onGoToMoloTerm(View v) { 

     map.animateCamera(CameraUpdateFactory.newCameraPosition(MoloTerminal)); 

    } 
    public void onGoToTagbakTerm(View v) { 

     map.animateCamera(CameraUpdateFactory.newCameraPosition(TagbakTerminal)); 

    } 
    public void onGoToCeresTerm(View v) { 

     map.animateCamera(CameraUpdateFactory.newCameraPosition(CeresTerminal)); 

    } 
} 

這裏的XML文件:

activity_locations.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:paddingTop="15dp" 
    android:paddingLeft="10dp" 
    android:paddingRight="10dp" 
    android:paddingBottom="10dp" 
    tools:context="com.thesis.iwander.TermLocActivity"> 

    <fragment xmlns:android="http://schemas.android.com/apk/res/android" 
     android:id="@+id/map" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_marginTop="?attr/actionBarSize" 
     class="com.google.android.gms.maps.SupportMapFragment"/> 

    <Button 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:text="Molo Term." 
     android:id="@+id/button" 
     android:onClick="onGoToMoloTerm" 
     android:layout_alignParentTop="true" 
     android:layout_alignParentLeft="true" 
     android:layout_alignParentStart="true" /> 

    <Button 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:text="Ceres Term." 
     android:id="@+id/button2" 
     android:onClick="onGoToCeresTerm" 
     android:layout_alignTop="@+id/button" 
     android:layout_toRightOf="@+id/button" 
     android:layout_toEndOf="@+id/button" 
     android:layout_marginLeft="13dp" /> 

    <Button 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:text="Tagbak Term." 
     android:id="@+id/button3" 
     android:onClick="onGoToTagbakTerm" 
     android:layout_alignTop="@+id/button2" 
     android:layout_alignRight="@+id/map" 
     android:layout_alignEnd="@+id/map" /> 
</RelativeLayout> 

所以每當我測試應用程序並點擊其中一個按鈕,應用程序崩潰和logcat顯示此錯誤:

FATAL EXCEPTION: main 
    Process: com.thesis.iwander, PID: 28783 
    java.lang.IllegalStateException: Could not execute method for android:onClick 
    at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener 
      .onClick(AppCompatViewInflater.java:293) 
    at android.view.View.performClick(View.java:4472) 
    at android.view.View$PerformClick.run(View.java:18779) 
    at android.os.Handler.handleCallback(Handler.java:808) 
    at android.os.Handler.dispatchMessage(Handler.java:103) 
    at android.os.Looper.loop(Looper.java:193) 
    at android.app.ActivityThread.main(ActivityThread.java:5333) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:829) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:645) 
    at dalvik.system.NativeStart.main(Native Method) 
    Caused by: java.lang.reflect.InvocationTargetException 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
     at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener 
     .onClick(AppCompatViewInflater.java:288) 
    at android.view.View.performClick(View.java:4472)  
     at android.view.View$PerformClick.run(View.java:18779)  
     at android.os.Handler.handleCallback(Handler.java:808)  
     at android.os.Handler.dispatchMessage(Handler.java:103)  
     at android.os.Looper.loop(Looper.java:193)  
     at android.app.ActivityThread.main(ActivityThread.java:5333)  
     at java.lang.reflect.Method.invokeNative(Native Method)  
    at java.lang.reflect.Method.invoke(Method.java:515)  
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:829)  
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:645)  
     at dalvik.system.NativeStart.main(Native Method)  
     Caused by: java.lang.NullPointerException 
      at com.thesis.iwander.TermLocActivity.onGoToCeresTerm(TermLocActivity.java:77) 
     at java.lang.reflect.Method.invokeNative(Native Method)  
      at java.lang.reflect.Method.invoke(Method.java:515)  
     at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener 
      .onClick(AppCompatViewInflater.java:288)  
     at android.view.View.performClick(View.java:4472)  
     at android.view.View$PerformClick.run(View.java:18779)  
     at android.os.Handler.handleCallback(Handler.java:808)  
      at android.os.Handler.dispatchMessage(Handler.java:103)  
      at android.os.Looper.loop(Looper.java:193)  
      at android.app.ActivityThread.main(ActivityThread.java:5333)  
      at java.lang.reflect.Method.invokeNative(Native Method)  
      at java.lang.reflect.Method.invoke(Method.java:515)  
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:829)  
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:645)  
      at dalvik.system.NativeStart.main(Native Method)  

我試圖找到類似於我的問題,但找不到任何問題。

+0

'產生的原因:在com.thesis.iwander.TermLocActivity.onGoToCeresTerm(TermLocActivity.java:77)顯示java.lang.NullPointerException'你還沒有顯示的代碼'onGoToCeresTerm()'。 – CommonsWare

+0

對不起,我編輯了這個問題。同樣的錯誤表明。 –

回答

5

您的對象GoogleMap map未初始化,因此您得到一個空指針異常

快速修復:

map = mapFragment.getMap();

+0

感謝您的回覆。我應該把它放在'onCreate()'方法嗎? –

+0

是的,* mapFragment.getMapAsync(this)之後; * –

+0

謝謝!我試過了,它工作。 –

1

您在xml中的onClick中名稱錯誤,Java文件中的錯誤名稱(它們需要匹配)或錯誤的簽名(它應該返回void並將單個View作爲參數)

+0

對不起,我編輯了這個問題。它顯示了相同的錯誤。 –

相關問題