google maps in android-fragment
Ich Probleme mit dem laden der google Karten in meinem fragment. Alles beginnt in einem recycler-Ansicht-adapter, die launchs der Aktivität "ViatgeDetallViewActivity" :
Context context = mActivity.getApplicationContext();
Intent intent = new Intent(context, ViatgeDetallViewActivity.class);
holder.mViatge.getId());
intent.putExtra("desc",p.getDesc());
intent.putExtra("location",p.getLocation());
mActivity.startActivityForResult(intent,ACTIVITY_View);
Dies ist mein DetallViewActivity :
public class ViatgeDetallViewActivity extends AppCompatActivity {
ViatgeDetallViewFragment fragment;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_view);
Bundle extras = getIntent().getExtras();
if(extras != null)
{
String s = getIntent().getStringExtra("desc");
Location l = getIntent().getParcelableExtra("location");
Log.d("myTag", "estoy en el oncreate de detallviewActivity pasando pro extras" + s );
}
fragment = new ViatgeDetallViewFragment();
getSupportFragmentManager().beginTransaction()
.add(R.id.activity_fragment_view, fragment)
.commit();
getFragmentManager().beginTransaction().add(R.id.activity_fragment_view, fragment).commit();
}
}
Mit meinem ViatgeDetallViewFragment :
public class ViatgeDetallViewFragment extends Fragment implements OnMapReadyCallback {
private GoogleMap mMap;
private Marker mMarcadorActual;
public ViatgeDetallViewFragment() {
}
....
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_view, container, false);
SupportMapFragment mapFragment =
(SupportMapFragment)
getChildFragmentManager().findFragmentById(R.id.fragment_view_map);
mapFragment.getMapAsync(this);
return rootView;
}
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
//ask for permissions..
mMap.setMyLocationEnabled(true);
LatLng sydney = new LatLng(-34, 151);
mMarcadorActual = mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
}
Mit den layouts wird , Activity_view:
<Linear ...
<android.support.v7.widget.Toolbar
android:id="@+id/tlbMenuView"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
android:elevation="4dp"
/>
<FrameLayout
android:id="@+id/activity_fragment_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
fragment_view:
<LinearLayout android:id="@+id/layout_fragment_view" xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent"
>
..
<fragment
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/fragment_view_map"
class="com.google.android.gms.maps.MapFragment"></fragment>
</LinearLayout>
Das problem kommt, wenn ich versuche zu starten tje "ViatgeDetallActivity" , dies bekomme ich im log:
FATAL EXCEPTION: main
Prozess: com.Beispiel.usuari.myapplication3, PID: 6390
java.lang.RuntimeException: Unable to start activity
ComponentInfo{com.example.usuari.myapplication3/com.example.usuari.myapplication3.ViatgeDetallViewActivity}:
java.lang.NullPointerException: Versuch zum aufrufen der virtuellen Methode void
com.google.android.gms.maps.SupportMapFragment.getMapAsync(com.google.android.gms.maps.OnMapReadyCallback)'
auf ein null-Objekt Verweis
bei
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3254)
bei
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3350)
an android.app.ActivityThread.Zugriff auf$1100(ActivityThread.java:222)
bei
android.app.ActivityThread$H. handleMessage(ActivityThread.java:1795)
an android.os.Handler.dispatchMessage(Handler.java:102)
an android.os.Looper.Loops(Looper.java:158)
an android.app.ActivityThread.main(ActivityThread.java:7229)
bei java.lang.reflektieren.Methode.invoke(Native-Methode)
bei
com.android.intern.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
bei com.android.intern.os.ZygoteInit.main(ZygoteInit.java:1120)
Verursacht durch: java.lang.NullPointerException: Versuch zum aufrufen der virtuellen
die Methode 'void
com.google.android.gms.maps.SupportMapFragment.getMapAsync(com.google.android.gms.maps.OnMapReadyCallback)'
auf ein null-Objekt Verweis
bei
com.example.usuari.myapplication3.ViatgeDetallViewFragment.onCreateView(ViatgeDetallViewFragment.java:82)
bei
android.Unterstützung.v4.app.Fragment.performCreateView(Fragment.java:2074)
bei
android.Unterstützung.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
bei
android.Unterstützung.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1286)
bei
android.Unterstützung.v4.app.BackStackRecord.run(BackStackRecord.java:758)
bei
android.Unterstützung.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1671)
bei
android.Unterstützung.v4.app.FragmentController.execPendingActions(FragmentController.java:388)
bei
android.Unterstützung.v4.app.FragmentActivity.onStart(FragmentActivity.java:619)
bei
android.app.Instrumentierung.callActivityOnStart(Instrumentation.java:1265)
an android.app.Aktivität.performStart(Aktivität.java:6915)
bei
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3217)
bei
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3350)
an android.app.ActivityThread.Zugriff auf$1100(ActivityThread.java:222)
bei
android.app.ActivityThread$H. handleMessage(ActivityThread.java:1795)
an android.os.Handler.dispatchMessage(Handler.java:102)
an android.os.Looper.Loops(Looper.java:158)
an android.app.ActivityThread.main(ActivityThread.java:7229)
bei java.lang.reflektieren.Methode.invoke(Native-Methode)
bei
com.android.intern.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
bei com.android.intern.os.ZygoteInit.main(ZygoteInit.java:1120)
03-24 02:55:53.871 6390-7362/com.Beispiel.usuari.myapplication3
W/DynamiteModule: Lokale Modul-Deskriptor-Klasse für
com.google.android.gms.googlecertificates nicht gefunden. 03-24
02:55:53.881 6390-7362/com.Beispiel.usuari.myapplication3
Ich/DynamiteModule: Berücksichtigung der lokalen Modul
com.google.android.gms.googlecertificates:0 und remote-Modul
com.google.android.gms.googlecertificates:2 03-24 02:55:53.881
6390-7362/com.Beispiel.usuari.myapplication3 ich/DynamiteModule: Ausgewählte
als remote-version com.google.android.gms.googlecertificates, version= 2 03-24 02:55:53.881 6390-7362/com.Beispiel.usuari.myapplication3 W/ResourcesManager: getTopLevelResources:
/data/user/0/com.google.android.gms/app_chimera/m/00000005/DynamiteModulesA_GmsCore_prodmnc_alldpi_release.apk
/1.0 läuft im com.Beispiel.usuari.myapplication3 rsrc Paket
com.Beispiel.usuari.myapplication3 03-24 02:55:53.891
6390-7362/com.Beispiel.usuari.myapplication3 D/ResourcesManager: Für
0 user neue overlays geholt Null 03-24 02:55:53.891
6390-7362/com.Beispiel.usuari.myapplication3 W/ResourcesManager:
getTopLevelResources:
/data/user/0/com.google.android.gms/app_chimera/m/00000005/DynamiteModulesA_GmsCore_prodmnc_alldpi_release.apk
/1.0 läuft im com.Beispiel.usuari.myapplication3 rsrc Paket
com.Beispiel.usuari.myapplication3
InformationsquelleAutor Asdemuertes | 2017-03-24
Du musst angemeldet sein, um einen Kommentar abzugeben.
Ihre
mapFragment
null ist. Versuchen Sie dies:InformationsquelleAutor K. Sopheak
Neueste update von Google Maps, nur MapView unterstützt wird für Fragmente.
Für mehr Info klicken Sie hier
InformationsquelleAutor Dhina k
wenn die oben genannte Lösung nicht funktioniert, versuchen Sie dies.
Fügen Sie diese in Ihre map-fragment
Und fügen Sie dieses in Ihrem Aufruf-Aktivität.
da die add-Methode hat nicht funktioniert also versuchte ich es ersetzen-Methode und es funktioniert nahtlos.
InformationsquelleAutor Anish Jain