android高德地图网络路径实现自定义marker并点击弹出自定义窗口
android中使用地图的地方随处可见,今天记录一下网络路径生成自定义marker,点击标记弹出自定义的窗口(在这里使用的是高德地图)
在这里我们使用Grilde去加载网络图片,因为这个简直太方便了!
在android studio下,在app/build.gradle文件当中添加如下依赖:
compile 'com.github.bumptech.glide:glide:3.7.0'
接下来就是代码的实现部分
代码注释的比较详细
/**
* Created by Yyyyq on 2018/4/20 0009.
* 根据网络路径生成自定义marker,点击弹出自定义窗体
*/
public class CustomMapActivity extends AppCompatActivity implements AMap.OnMarkerClickListener,
AMap.InfoWindowAdapter,AMap.OnMapClickListener{
//标题头
private TextView textView;
//返回按钮
private ImageView back;
private MapView mMapView;
private AMap aMap;
Marker marker;
//指向当前的marker(用于控制infowindow显示与消失)
Marker nowMarker;
SimpleVO tempSimpleVO;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_custommap);
mMapView = (MapView) findViewById(R.id.map);
mMapView.onCreate(savedInstanceState);
init();
back=(ImageView)findViewById(R.id.back);
textView = (TextView) findViewById(R.id.toolbar_title);
Toolbar toolbar = (Toolbar) findViewById(R.id.activity_main_toolbar);
textView.setText("生成网络图片Marker");
toolbar.setTitle("");
setSupportActionBar(toolbar);
setTranslucentBar();
//返回按钮
back.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
finish();
}
});
}
private void init() {
if (aMap == null) {
aMap = mMapView.getMap();
setUpMap();
//获取后台数据源
getDataSource();
}
}
/**
* 设置aMap属性
*/
private void setUpMap() {
aMap.setOnMarkerClickListener(this);// 设置点击marker事件监听器
aMap.setInfoWindowAdapter(this);//自定义弹出窗体
aMap.setOnMapClickListener(this);//地图点击事件
}
/**
* @Description:沉浸式标题
*/
protected void setTranslucentBar() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
Window window = getWindow();
// Translucent status bar
window.setFlags(
WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS,
WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
}
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
}
/**
*在这里模拟方法请求到数据源,可根据实际
* 我们用自定义实体类SimpleVO接收数据源
*/
private void getDataSource(){
//网络请求 得到List
List<SimpleVO> list="后台传递的数据源";
if(list.size()>0){
//根据第一条数据经纬度经地图移动到所视区域
LatLng curLatlng = new LatLng(Double.parseDouble(list.get(0).getLatitude()),Double.parseDouble(list.get(0).getLongitude()));
aMap.moveCamera(CameraUpdateFactory.newLatLngZoom(curLatlng, 14f));
for(int i=0;i<list.size();i++){
final int j = i;
//利用强大的Glide加载图片,可放占位符等,可百度Glide属性
Glide.with(CustomMapActivity.this)
.load(list.get(i).getUrl())
.into(new SimpleTarget<GlideDrawable>(){
@Override
public void onResourceReady(GlideDrawable resource, GlideAnimation<? super GlideDrawable> glideAnimation) {
//展示图片
View view = LayoutInflater.from(CustomMapActivity.this).inflate(
R.layout.map_userimg, null);
RoundImageView imageView = (RoundImageView) view.findViewById(R.id.user_img);
tempSimpleVO=list.get(j);
imageView.setImageDrawable(resource);
Bitmap bitmap = convertViewToBitmap(view);
MarkerOptions markerOptions = new MarkerOptions();
markerOptions.anchor(1.5f, 3.5f);
markerOptions.position(new LatLng(Double.parseDouble(tempSimpleVO.getLatitude()),Double.parseDouble(tempSimpleVO.getLongitude())));
markerOptions.draggable(false);
markerOptions.title(tempSimpleVO.getName());
markerOptions.icon(BitmapDescriptorFactory.fromBitmap(bitmap));
marker = aMap.addMarker(markerOptions);
//把相应的对象赋给marker,adapter中通过这个对象给控件赋值
marker.setObject(tempSimpleVO);
}
});
}
}
}
/**
* 点击marker弹出窗口
* 返回true 地图不移动中心点
*/
@Override
public boolean onMarkerClick(Marker marker) {
nowMarker=marker;
nowMarker.showInfoWindow();
return true;
}
/**
* 自定义窗口布局
*/
@Override
public View getInfoWindow(Marker marker) {
View infoContent = LayoutInflater.from(CustomMapActivity.this).inflate(
R.layout.item_map_window, null);
render(marker, infoContent,2);
return infoContent;
}
/**
* 对窗口信息赋值
*/
public void render(Marker marker, View view,int mark) {
LinearLayout layout = (LinearLayout) view.findViewById(R.id.window_linearlayout);
//设置透明度
layout.getBackground().setAlpha(240);
TextView name = (TextView) view.findViewById(R.id.window_name);
TextView info = (TextView) view.findViewById(R.id.window_info);
SimpleVO simpleVO = (SimpleVO) marker.getObject();
name.setText(simpleVO.getName());
info.setText(simpleVO.getInfo());
}
/**
* 因自定义窗口 返回null
*/
@Override
public View getInfoContents(Marker marker) {
return null;
}
/**
* 重写地图点击事件,点击地图任意点隐藏infowindow窗口
*/
@Override
public void onMapClick(LatLng latLng) {
//隐藏infowindow窗口
nowMarker.hideInfoWindow();
}
@Override
protected void onResume() {
super.onResume();
mMapView.onResume();
}
@Override
protected void onPause() {
super.onPause();
mMapView.onPause();
}
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
mMapView.onSaveInstanceState(outState);
}
@Override
protected void onDestroy() {
super.onDestroy();
mMapView.onDestroy();
}
/**
* view转bitmap
*/
private static Bitmap convertViewToBitmap(View view){
view.measure(View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED), View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED));
view.layout(0, 0, view.getMeasuredWidth(), view.getMeasuredHeight());
view.buildDrawingCache();
Bitmap bitmap = view.getDrawingCache();
return bitmap;
}
}
接下来就是主页面的布局 activity_custommap
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<!--标题栏-->
<android.support.v7.widget.Toolbar
android:id="@+id/activity_main_toolbar"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:paddingTop="16dp"
android:minHeight="?attr/actionBarSize"
android:background="@color/bluestyle_button">
<ImageView
android:id="@+id/back"
android:layout_width="25dp"
android:layout_height="25dp"
android:layout_marginLeft="10dp"
android:layout_gravity="center|left"
android:src="@drawable/jiantouzuo"/>
<TextView
android:id="@+id/toolbar_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:textColor="#fff"
android:textSize="18sp"/>
</android.support.v7.widget.Toolbar>
<com.amap.api.maps.MapView
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/map"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
代码中应用的实力类 SimpleVO
public class SimpleVO {
private String id;
private String name;
private String latitude;
private String longitude;
private String url;
private String info;
//省略get,set,toString方法,需自己导入
}
之后需要展示我们的自定义头像 map_userimg 因为展示的是头像,我们用到了圆形工具类,若没有该工具类可查看复制上一篇随笔,可直接粘贴复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center">
<!--自定义圆形工具类-->
<!--若没有该工具类可赋值上一篇代码,Ctrl+c Ctrl+v可用-->
<com.bc.yyyyq.util.RoundImageView
android:id="@+id/user_img"
android:scaleType="fitCenter"
android:layout_width="30dp"
android:layout_height="30dp"/>
</LinearLayout>
最后我们需要展示我们自定义的marker的弹出窗体 item_map_window
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/window_linearlayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/brokermap_layout"
android:padding="10dp"
android:orientation="vertical">
<!--姓名-->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="30dp"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:gravity="center"
android:text="姓名:"
android:textColor="#515151"
android:textSize="14sp"/>
<TextView
android:id="@+id/window_name"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginLeft="5dp"
android:gravity="center|left"
android:text=""
android:textColor="#515151"
android:textSize="14sp"/>
</LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="#f2f2f2" />
<!--个人信息-->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="30dp"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:text="个人信息:"
android:gravity="center"
android:textColor="#515151"
android:textSize="14sp"/>
<TextView
android:id="@+id/window_info"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center|left"
android:layout_marginLeft="5dp"
android:text=""
android:textColor="#515151"
android:textSize="14sp"/>
</LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="#f2f2f2" />
</LinearLayout>
就这样就完成了自定义网络图片的marker和点击标识弹出我们自定义的窗口,想要的效果就展示出来了
android高德地图网络路径实现自定义marker并点击弹出自定义窗口的更多相关文章
- Android高德地图自定义Markers的例子
下文为各位重点介绍关于Android高德地图自定义Markers的例子,希望这篇文章能够让各位理解到Android高德地图自定义Markers的方法. 之前的博客里说了地图的嵌入和定位,今天就说说在地 ...
- android 高德地图出现【定位失败key鉴权失败】
如题:android 高德地图出现[定位失败key鉴权失败] 原因:使用的是debug模式下的SHA1,发布的版本正确获取SHA1的方式见: 方法二使用 keytool(jdk自带工具),按照如下步骤 ...
- android 高德地图API 之 java.lang.UnsatisfiedLinkError: Couldn't load amapv3: findLibrary returned null错误
错误场景: 运行android app时,在运行到调用高德地图API时,出现 “java.lang.UnsatisfiedLinkError: Couldn't load amapv3: findLi ...
- 实现android手机来电拦截系统页面弹出自定义页面特效
如何实现android手机来电拦截系统页面弹出自定义页面特效, 首先: 我们需要注册一个监听来电的广播PhoneStateReceiver 类:其次: 在onReceive里面我们获取an ...
- Android高德地图开发具体解释
这段时间开发的时候用到了高德地图,对高德地图开发有心得体会,如今分享给大家.对我开发过百度地图的我来说,整体来说高德地图Demo,没有百度解说的具体 个人更偏向于使用百度地图,可是没办发,项目须要使用 ...
- Android 高德地图使用小记
感谢大佬:https://www.cnblogs.com/devilmaycry812839668/p/8727569.html 高德地图 Android编程中 如何设置使 标记 marker 能够被 ...
- 实例源码--Android高德地图实例源码
下载源码 技术要点: 1.高德地图 API的使用 2.定位 ,查询路线,公交查询等地图相关技术 3.源码带有非常详 细的中文注释 ...... 详细介绍: 1. 高德地图API的使用 本套实例采 ...
- Android 高德地图 java.lang.UnsatisfiedlinkError Native method not found: com.autonavi.amap.mapcore.MapCore.nativeNewInstance:(Ljava/lang/String;)
在Android项目中引用高德地图,程序运行时出现上述问题,如果引用了Map3D的jar包,则需要在引入Jar文件的同时引入so文件,在高德地图的demo中,找到so文件: 然后将其复制到jniLib ...
- Android 高德地图No implementation found for long com.autonavi.amap.mapcore.MapCore
此篇博客最后更新时间写自2016.5.18.当下高德地图jar版本为3.3.1. 使用高德地图碰到此问题,纠结许久(接近4个多小时). 记录在此,希望遇到相同问题的读者可以有所借鉴. 错误截图: 导致 ...
随机推荐
- 25.C++- 泛型编程之函数模板(详解)
本章学习: 1)初探函数模板 2)深入理解函数模板 3)多参函数模板 4)重载函数和函数模板 当我们想写个Swap()交换函数时,通常这样写: void Swap(int& a, int&am ...
- 新概念英语(1-133)Sensational news!
Lesson 133 Sensational news! 爆炸性新闻! Listen to the tape then answer this question. What reason did Ka ...
- 租户、租户管理员、部门管理员和开发者在APIGW中的角色
一.参与者 1.vdcId:租户 2.运营管理员 operator: 一种角色 创建开发商 审批外置服务,如:hadoop集群 审批内置服务,如:<API使用申请> 3.租户管理员 ...
- 两款不同应用场景的Wpf分页控件
简介 今天给大家分享两个Wpf分页控件,本篇博客主要介绍一些实现思路和使用方法,具体实现和应用代码请参考文末的Demo链接 废话不多说,先看一下效果~ (两款控件显示效果是一样的) 实现思路 一款控件 ...
- 百度echarts使用--y轴label数字太长难以全部显示
问题: 今天遇到个小问题,我们系统前端呈现使用了百度echarts.在绘制折线图的时候,因为数字过大,导致显示出现了问题. 解决方案: 左边y轴的值默认是根据我们填充进去的值来默认分割的,因为原始值就 ...
- 理解JavaScript中的call和apply方法
call方法 总的来说call()有这几种作用:1.可以借用另一个对象的方法.2.改变this的指向(重要).3.将arguments数组化.下面详细介绍这三种作用: 1.可以借用另一个对象的方法:当 ...
- Java-NIO(七):阻塞IO与非阻塞IO
阻塞IO 传统的 IO 流都是阻塞式的. 也就是说,当一个线程调用 read() 或 write()时,该线程被阻塞,直到有一些数据被读取或写入,该线程在此期间不能执行其他任务. 因此,在完成网络通信 ...
- QT 设计师使用样式表添加背景
QT create中样式表可以用来设置背景图.背景颜色.字体大小格式颜色等 1.添加背景图的话需要先添加资源文件 右击项目文件选择添加新文件,再选择QT资源文件(QT resource file)然后 ...
- 面向面试题和实际使用谈promise
"金三银四,金九银十",都是要收获的季节.面对各种面试题,各种概念.原理都要去记,挺枯燥的.本文是面向面试题和实际使用谈一下Promise. Promise是什么? Promise ...
- 【转】Impala导出查询结果到文件
[转载出处]http://blog.csdn.net/jobschen/article/details/68942574 想用impala-shell 命令行中将查询的结果导出到本地文件,想当然的以为 ...