在 Viewpager 上添加带有标记的 Google 地图
Posted
技术标签:
【中文标题】在 Viewpager 上添加带有标记的 Google 地图【英文标题】:Adding Google maps with marker on a Viewpager 【发布时间】:2017-05-23 09:51:46 【问题描述】:我正在尝试创建一个具有两个选项卡的应用程序。 第一个选项卡包含我的所有联系人及其工作正常。第二个选项卡应包含一个地图,显示所有已保存位置的联系人的标记。
谷歌地图正确呈现,没有任何错误,但是如何在其中放置标记?
这是 Viewpager 片段:
package com.example.contacts_mapapp;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toast;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
public class ContactMap extends Fragment implements OnMapReadyCallback
// TODO: Rename parameter arguments, choose names that match
// the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
private static final String ARG_PARAM1 = "param1";
private static final String ARG_PARAM2 = "param2";
// TODO: Rename and change types of parameters
private String mParam1;
private String mParam2;
// Google Map
private SupportMapFragment googleMap;
View view;
public ContactMap()
// Required empty public constructor
/**
* Use this factory method to create a new instance of
* this fragment using the provided parameters.
*
* @param param1 Parameter 1.
* @param param2 Parameter 2.
* @return A new instance of fragment ContactMap.
*/
// TODO: Rename and change types and number of parameters
public static ContactMap newInstance(String param1, String param2)
ContactMap fragment = new ContactMap();
Bundle args = new Bundle();
args.putString(ARG_PARAM1, param1);
args.putString(ARG_PARAM2, param2);
fragment.setArguments(args);
return fragment;
@Override
public void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
if (getArguments() != null)
mParam1 = getArguments().getString(ARG_PARAM1);
mParam2 = getArguments().getString(ARG_PARAM2);
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState)
// Inflate the layout for this fragment
view= inflater.inflate(R.layout.fragment_contact_map, container, false);
try
// Loading map
FragmentManager fragmentManager = getChildFragmentManager();
googleMap = ((SupportMapFragment) fragmentManager.findFragmentById(R.id.map));
googleMap.getMapAsync((OnMapReadyCallback) getActivity());
// check if map is created successfully or not
if (googleMap == null)
googleMap = SupportMapFragment.newInstance();
fragmentManager.beginTransaction().replace(R.id.map,googleMap).commit();
Toast.makeText(getActivity().getApplicationContext(),
"Sorry! unable to create maps", Toast.LENGTH_SHORT)
.show();
catch (Exception e)
e.printStackTrace();
return view;
@Override
public void onMapReady(GoogleMap googleMap)
LatLng sydney = new LatLng(-33.852, 151.211);
googleMap.addMarker(new MarkerOptions().position(sydney)
.title("Marker in Sydney"));
googleMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
XML 文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
tools:context="com.example.contacts_mapapp.ContactMap">
<!-- TODO: Update blank fragment layout -->
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:map="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/map"
android:name="com.google.android.gms.maps.SupportMapFragment"
android:layout_
android:layout_
tools:layout="@layout/fragment_contact_map"/>
</RelativeLayout>
【问题讨论】:
您已经在onMapReady
中添加标记,有什么问题?
我还是看不到标记
【参考方案1】:
将您的 googleMap.getMapAsync((OnMapReadyCallback) getActivity());
更改为 googleMap.getMapAsync(this);
并让我知道它是否可以解决您的问题。
【讨论】:
欢迎。如果有帮助,请投票并接受答案,因此对其他人有帮助:)【参考方案2】:将 googleMap(在 onCreateView 中初始化的变量)分配给 onMapReady() 中的变量 googleMap。你已经在 onCreatView 中初始化了
@Override
public void onMapReady(GoogleMap googleMap)
googleMap = googleMap;
LatLng sydney = new LatLng(-33.852, 151.211);
googleMap.addMarker(new MarkerOptions().position(sydney)
.title("Marker in Sydney"));
googleMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
【讨论】:
以上是关于在 Viewpager 上添加带有标记的 Google 地图的主要内容,如果未能解决你的问题,请参考以下文章
在ViewPager上,在onPageSelected上的片段上启动动画
使用 TabLayout 在 ViewPager 中的 Google 地图片段中膨胀异常
布局 XML 文件上的 android.support.v4.view.ViewPager 和 android.support.v7.widget.CardView 标记出错