热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android百度地图定位实现仿钉钉签到打卡功能的完整代码

这篇文章主要介绍了Android百度地图定位实现仿钉钉签到打卡功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

导语

本章根据百度地图API,实现仿钉钉打卡功能。用到了基础地图、覆盖物、定位图层、陀螺仪方法、悬浮信息弹框。

百度地图API地址  :Android 地图SDK

请先注册注册百度账号和获取密钥,并实现地图显示出来。(注意:密钥、权限要设置)

另外,我得说明本章所下载官方Demo 和 导入的jar包和so文件。自定义下载即可,如下图:

接下来,一起看实现效果。

源码Git地址:BaiduMapApp

效果图        

   

实现代码·三步骤

第一步:基础地图和方向传感器

类先实现方向传感器 implements SensorEventListener

@Override
 public void onSensorChanged(SensorEvent sensorEvent) {
  double x = sensorEvent.values[SensorManager.DATA_X];
  if (Math.abs(x - lastX) > 1.0) {
   mCurrentDirection = (int) x;
   locData = new MyLocationData.Builder()
     // 此处设置开发者获取到的方向信息,顺时针0-360
     .direction(mCurrentDirection).latitude(mCurrentLat)
     .longitude(mCurrentLon).build();
   mBaiduMap.setMyLocationData(locData);
  }
  lastX = x;
 }
 
 @Override
 public void onAccuracyChanged(Sensor sensor, int i) {
 
 }
 /**
  * 初始化地图
  */
 private void initBaiduMap() {
  mMapView = (MapView) findViewById(R.id.mapview);
  mBaiduMap = mMapView.getMap();
  mBaiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);
  mBaiduMap.setMyLocationEnabled(true);//开启定位图层
  mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);//获取传感器管理服务
 }
@Override
 protected void onResume() {
  super.onResume();
  mMapView.onResume();
  //为系统的方向传感器注册监听器
  mSensorManager.registerListener(this, mSensorManager.getDefaultSensor(Sensor.TYPE_ORIENTATION),
    SensorManager.SENSOR_DELAY_UI);
 }
 @Override
 protected void onPause() {
  super.onPause();
  mMapView.onPause();
 }
 
 @Override
 protected void onStop() {
  super.onStop();
  //取消注册传感器监听
  mSensorManager.unregisterListener(this);
 }

第二步:开启定位

 /***
  * 定位选项设置
  * @return
  */
 public void getLocationClientOption() {
  mOption = new LocationClientOption();
  mOption.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);//可选,默认高精度,设置定位模式,高精度,低功耗,仅设备
  mOption.setCoorType("bd09ll");//可选,默认gcj02,设置返回的定位结果坐标系,如果配合百度地图使用,建议设置为bd09ll;
  mOption.setScanSpan(2000);//可选,默认0,即仅定位一次,设置发起连续定位请求的间隔需要大于等于1000ms才是有效的
  mOption.setIsNeedAddress(true);//可选,设置是否需要地址信息,默认不需要
  mOption.setIsNeedLocationDescribe(true);//可选,设置是否需要地址描述
  mOption.setNeedDeviceDirect(true);//可选,设置是否需要设备方向结果
  mOption.setLocationNotify(true);//可选,默认false,设置是否当gps有效时按照1S1次频率输出GPS结果
  mOption.setIgnoreKillProcess(true);//可选,默认true,定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程,默认不杀死
  mOption.setIsNeedLocationDescribe(false);//可选,默认false,设置是否需要位置语义化结果,可以在BDLocation.getLocationDescribe里得到,结果类似于“在北京天安门附近”
  mOption.setIsNeedLocationPoiList(false);//可选,默认false,设置是否需要POI结果,可以在BDLocation.getPoiList里得到
  mOption.SetIgnoreCacheException(false);//可选,默认false,设置是否收集CRASH信息,默认收集
  mOption.setOpenGps(true);//可选,默认false,设置是否开启Gps定位
  mOption.setIsNeedAltitude(false);//可选,默认false,设置定位时是否需要海拔信息,默认不需要,除基础定位版本都可用
  client = new LocationClient(this);
  client.setLocOption(mOption);
  client.registerLocationListener(BDAblistener);
  client.start();
 }
 /***
  * 接收定位结果消息,并显示在地图上
  */
 private BDAbstractLocationListener BDAblistener = new BDAbstractLocationListener() {
  @Override
  public void onReceiveLocation(BDLocation location) {
   //定位方向
   mCurrentLat = location.getLatitude();
   mCurrentLon = location.getLongitude();
   //个人定位
   locData = new MyLocationData.Builder()
     .direction(mCurrentDirection).latitude(location.getLatitude())
     .longitude(location.getLongitude()).build();
   mBaiduMap.setMyLocationData(locData);
   mBaiduMap.setMyLocationConfiguration(new MyLocationConfiguration(
     MyLocationConfiguration.LocationMode.NORMAL, true, null));
   //更改UI
   Message message = new Message();
   message.obj = location;
   mHandler.sendMessage(message);
  }
 };

第三步:更改UI

 //设置打卡目标范围圈
 private void setCircleOptions() {
  if (mDestinatiOnPoint== null) return;//打卡坐标不能为空
  OverlayOptions ooCircle = new CircleOptions().fillColor(0x4057FFF8)
    .center(mDestinationPoint).stroke(new Stroke(1, 0xB6FFFFFF)).radius(DISTANCE);
  mBaiduMap.addOverlay(ooCircle);
 }
 /**
  * 添加地图文字
  *
  * @param point
  * @param str
  * @param color 字体颜色
  */
 private void setTextOption(LatLng point, String str, String color) {
  //使用MakerInfoWindow
  if (point == null) return;
  TextView view = new TextView(getApplicationContext());
  view.setBackgroundResource(R.mipmap.map_textbg);
  view.setPadding(0, 23, 0, 0);
  view.setTypeface(Typeface.DEFAULT_BOLD);
  view.setTextSize(14);
  view.setGravity(Gravity.CENTER);
  view.setText(str);
  view.setTextColor(Color.parseColor(color));
  mInfoWindow = new InfoWindow(view, point, 170);
  mBaiduMap.showInfoWindow(mInfoWindow);
 }
 /**
  * 设置marker覆盖物
  *
  * @param ll 坐标
  * @param icon 图标
  */
 private void setMarkerOptions(LatLng ll, int icon) {
  if (ll == null) return;
  BitmapDescriptor bitmap = BitmapDescriptorFactory.fromResource(icon);
  MarkerOptions ooD = new MarkerOptions().position(ll).icon(bitmap);
  mBaiduMap.addOverlay(ooD);
 }
 //改变地图缩放
 private void setMapZoomScale(LatLng ll) {
  if (mDestinatiOnPoint== null) {//打卡坐标不为空
   mZoomScale = getZoomScale(ll);
   mBaiduMap.animateMapStatus(MapStatusUpdateFactory.newLatLngZoom(ll, mZoomScale));//缩放
  } else {
   mZoomScale = getZoomScale(ll);
   mBaiduMap.animateMapStatus(MapStatusUpdateFactory.newLatLngZoom(mCenterPos, mZoomScale));//缩放
  }
 }
 /**
  * 获取地图的中心点和缩放比例
  *
  * @return float
  */
 private float getZoomScale(LatLng LocationPoint) {
  double maxLong; //最大经度
  double minLong; //最小经度
  double maxLat;  //最大纬度
  double minLat;  //最小纬度
  List lOngItems= new ArrayList(); //经度集合
  List latItems = new ArrayList();  //纬度集合
 
  if (null != LocationPoint) {
   longItems.add(LocationPoint.longitude);
   latItems.add(LocationPoint.latitude);
  }
  if (null != mDestinationPoint) {
   longItems.add(mDestinationPoint.longitude);
   latItems.add(mDestinationPoint.latitude);
  }
 
  maxLOng= longItems.get(0); //最大经度
  minLOng= longItems.get(0); //最小经度
  maxLat = latItems.get(0);  //最大纬度
  minLat = latItems.get(0);  //最小纬度
 
  for (int i = 0; i 

实现时间显示

 /**
  * 设置系统时间
  */
 private Runnable run = new Runnable() {
  @Override
  public void run() {
   SimpleDateFormat simpleDateFormat = new SimpleDateFormat("HH:mm:ss");// HH:mm:ss
   Date date = new Date(System.currentTimeMillis());//获取当前时间
   mTime_tv.setText(simpleDateFormat.format(date)); //更新时间
   mHandler.postDelayed(run, 1000);
  }
 };
  mHandler.post(run);//设置系统时间

最后,收尾操作

 @Override
 protected void onDestroy() {
  if (BDAblistener != null) {
   client.unRegisterLocationListener(BDAblistener);
 
  }
  if (client != null && client.isStarted()) {
   client.stop();
  }
  mMapView.onDestroy();
  mMapView = null;
  mHandler.removeCallbacks(run);
  super.onDestroy();
 }

源码地址:https://github.com/aiyangtianci/BaiduMapApp

总结

到此这篇关于Android 百度地图定位实现仿钉钉签到打卡功能的文章就介绍到这了,更多相关android 钉钉签到打卡内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!


推荐阅读
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 学习笔记(34):第三阶段4.2.6:SpringCloud Config配置中心的应用与原理第三阶段4.2.6SpringCloud Config配置中心的应用与原理
    立即学习:https:edu.csdn.netcourseplay29983432482?utm_sourceblogtoedu配置中心得核心逻辑springcloudconfi ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 【Windows】实现微信双开或多开的方法及步骤详解
    本文介绍了在Windows系统下实现微信双开或多开的方法,通过安装微信电脑版、复制微信程序启动路径、修改文本文件为bat文件等步骤,实现同时登录两个或多个微信的效果。相比于使用虚拟机的方法,本方法更简单易行,适用于任何电脑,并且不会消耗过多系统资源。详细步骤和原理解释请参考本文内容。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • 【MicroServices】【Arduino】装修甲醛检测,ArduinoDart甲醛、PM2.5、温湿度、光照传感器等,数据记录于SD卡,Python数据显示,UI5前台,微服务后台……
    这篇文章介绍了一个基于Arduino的装修甲醛检测项目,使用了ArduinoDart甲醛、PM2.5、温湿度、光照传感器等硬件,并将数据记录于SD卡,使用Python进行数据显示,使用UI5进行前台设计,使用微服务进行后台开发。该项目还在不断更新中,有兴趣的可以关注作者的博客和GitHub。 ... [详细]
author-avatar
ndo2205188
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有