У меня проблема с интеграцией карты Google в фрагменте в android. Я знаю, как это сделать в процессе работы, но ссылки на фрагменты на этом сайте очень старые и не работают в 2018 году. У меня нет ошибок. Ниже приведен файл фрагментов. Любая помощь будет принята с благодарностью. Я добавил ключ API и соответствующий файл манифеста.
package com.example.narmail.truck30mint.Api.Fragments;
import android.Manifest;
import android.content.Context;
import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.net.Uri;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.app.Fragment;
import android.support.v4.content.ContextCompat;
import android.support.v7.app.AlertDialog;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import com.example.narmail.truck30mint.R;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.MapView;
import com.google.android.gms.maps.MapsInitializer;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.model.CameraPosition;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
import java.util.ArrayList;
public class ViewTrucksFragment extends Fragment {
TextView pageTitle;
MapView mMapView;
private GoogleMap googleMap;
public ViewTrucksFragment() {
// Required empty public constructor
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View rootView = inflater.inflate(R.layout.fragment_view_trucks, container, false);
pageTitle = rootView.findViewById(R.id.view_trucks_title);
String load_id = getArguments().getString("load_id");
String load_from = getArguments().getString("load_from");
String load_to = getArguments().getString("load_to");
if (load_id != null && load_from != null && load_to != null) {
pageTitle.setText("Matching Trucks for "+load_from+" to "+load_to);
}
mMapView= rootView.findViewById(R.id.view_trucks_map);
mMapView.onCreate(savedInstanceState);
mMapView.onResume();
try {
MapsInitializer.initialize(getActivity().getApplicationContext());
} catch (Exception e) {
e.printStackTrace();
}
mMapView.getMapAsync(new OnMapReadyCallback() {
@Override
public void onMapReady(GoogleMap mMap) {
googleMap = mMap;
googleMap.getUiSettings().setCompassEnabled(true);
googleMap.getUiSettings().setMyLocationButtonEnabled(true);
googleMap.getUiSettings().setRotateGesturesEnabled(true);
// For dropping a marker at a point on the Map
LatLng sydney = new LatLng(30.374219,76.782055);
googleMap.addMarker(new MarkerOptions().position(sydney).
title("Title").snippet("TitleName"));
// For zooming automatically to the location of the marker
CameraPosition cameraPosition = new CameraPosition.Builder().target(sydney).zoom(12).build();
googleMap.animateCamera(CameraUpdateFactory.newCameraPosition
(cameraPosition ));
}
});
/*----------------*/
return rootView;
}
}
и ниже мой файл макета
<?xml version = "1.0" encoding = "utf-8"?>
<FrameLayout 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:background = "@color/colorWhite"
tools:context = ".Api.Fragments.ViewTrucksFragment">
<LinearLayout
android:orientation = "vertical"
android:layout_width = "match_parent"
android:layout_height = "match_parent">
<TextView
android:id = "@+id/view_trucks_title"
android:layout_width = "match_parent"
android:layout_height = "match_parent"
android:textAlignment = "center"
android:layout_marginRight = "10dp"
android:layout_marginLeft = "10dp"
android:padding = "10dp"
android:textColor = "@color/colorPrimary"
android:textSize = "15sp"
android:text = "@string/hello_blank_fragment" />
<com.google.android.gms.maps.MapView
android:id = "@+id/view_trucks_map"
android:layout_width = "match_parent"
android:layout_height = "match_parent">
</com.google.android.gms.maps.MapView>
</LinearLayout>
</FrameLayout>
Пожалуйста, следуйте шагу ниже, чтобы завершить свою задачу. Просто нужно создать 3 файла
(1) Создайте макет XML для карты внутри макета фрагмента fragment_map.xml
<?xml version = "1.0" encoding = "utf-8"?>
<fragment xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/map"
android:name = "com.google.android.gms.maps.SupportMapFragment"
android:layout_width = "match_parent"
android:layout_height = "match_parent" />
(2) Создайте фрагмент для загрузки MAP MapFragment.Java
public class MapFragment extends Fragment implements OnMapReadyCallback {
private GoogleMap mMap;
public MapFragment() {
// Required empty public constructor
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.fragment_map, container, false);
}
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
if (getActivity()!=null) {
SupportMapFragment mapFragment = (SupportMapFragment) getActivity().getSupportFragmentManager()
.findFragmentById(R.id.map);
if (mapFragment != null) {
mapFragment.getMapAsync(this);
}
}
}
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
//Do your stuff here
}
}
(3) Создайте действие для загрузки фрагмента карты MapsActivity.java.
public class MapsActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_maps);
FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
fragmentTransaction.add(R.id.content,new MapFragment());
fragmentTransaction.commit();
}
}
Для ключа MAP вам необходимо выполнить тот же шаг, который вы сделали в своем проекте. Надеюсь, этот шаг вам поможет.
Внутри Gradle используйте ниже Gradle
implementation 'com.google.android.gms:play-services-maps:15.0.1'
AndroidManifest.xml определяет следующие вещи.
<uses-permission android:name = "android.permission.INTERNET"/>
Внутри тега приложения.
<meta-data
android:name = "com.google.android.geo.API_KEY"
android:value = "YOUR MAP KEY" />
он выдает ошибку: не найден подходящий метод для add (int, MapFragment), метод FragmentTransaction.add (Fragment, String) не применим (несоответствие аргументов; int не может быть преобразован в Fragment) метод FragmentTransaction.add (int, Fragment) не применимо (несоответствие аргументов; MapFragment не может быть преобразован во фрагмент)
Пожалуйста, проверьте правильность функции add (), я думаю, вы используете неправильную функцию.
Ваше решение показывает активность на всей странице, но я не могу этого сделать, потому что я использую панель навигации в основном действии и показываю все элементы в нескольких фрагментах. Пожалуйста, покажите какое-нибудь решение в соответствии с этим
Это всего лишь пример с фрагментом, который вам нужно изменить в соответствии с вашими требованиями.
Я сделал это с помощью mapView, ошибка была в макете. Высота TextLayout была установлена в соответствии с родительским, а карта была скрыта за ним
Хорошо, Поздравляем !!! Если вам понравился мой ответ, вы можете отметить мой ответ как проверенный.
Конечно, вы заслуживаете и благодарите за то, что пожертвовали сообществу.