2016-03-06 114 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

对不起,我编辑了这个问题。它显示了相同的错误。 –

相关问题