2024年安卓最新Android百度地图——定位SDK(版本v3(1),2024年最新安卓常见面试题

最后

我的面试经验分享可能不会去罗列太多的具体题目,因为我依然认为面试经验中最宝贵的不是那一个个具体的题目或者具体的答案,而是结束面试时,那一刻你的感受以及多天之后你的回味~

很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候,总会遇到一些问题,比如学了一段时间感觉没有方向感,不知道该从那里入手去学习,对此我整理了一些资料,需要的可以免费分享给大家

在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

【算法合集】

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

**Android精讲视频领取学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

    // 设置定位方式的优先级。

    // 当gps可用,而且获取了定位结果时,不再发起网络请求,直接返回给用户坐标。这个选项适合希望得到准确坐标位置的用户。如果gps不可用,再发起网络请求,进行定位。

    option.setPriority(LocationClientOption.GpsFirst);



二、设置定位时间间隔:



 百度API里的说明:



      1、当所设的整数值大于等于1000(ms)时,定位SDK内部使用定时定位模式。调用requestLocation( )后,每隔设定的时间,定位SDK就会进行一次定位。如果定位SDK根据定位依据发现位置没有发生变化,就不会发起网络请求,返回上一次定位的结果;如果发现位置改变,就进行网络请求进行定位,得到新的定位结果。定时定位时,调用一次requestLocation,会定时监听到定位结果。



      2、当不设此项,或者所设的整数值小于1000(ms)时,采用一次定位模式。每调用一次requestLocation( ),定位SDK会发起一次定位。请求定位与监听结果一一对应。



      3、设定了定时定位后,可以热切换成一次定位,需要重新设置时间间隔小于1000(ms)即可。locationClient对象stop后,将不再进行定位。如果设定了定时定位模式后,多次调用requestLocation(),则是每隔一段时间进行一次定位,同时额外的定位请求也会进行定位,但频率不会超过1秒一次。         



我实际调用了下,LocationClientOption对象其它属性设置不变。当所设的整数值大于等于1000(ms)时,会每隔设定的时间就重新定位一次。



// 定位的时间间隔,单位:ms

    // 当所设的整数值大于等于1000(ms)时,定位SDK内部使用定时定位模式。

    option.setScanSpan(1000);



三、完整代码:



package com.android.baidu.map;

import android.app.Activity;

import android.os.Bundle;

import android.util.Log;

import android.view.View;

import android.widget.TextView;

import com.baidu.location.BDLocation;

import com.baidu.location.BDLocationListener;

import com.baidu.location.LocationClient;

import com.baidu.location.LocationClientOption;

/**

  • 通过GPS定位获取值

  • @author android_ls

*/

public class BaiduMapLoaction2Activity extends Activity {

private static final String TAG = "BaiduMapLoactionActivity";



private LocationClient mLocationClient;



private MyBDLocationListener mBDLocationListener;



private TextView mContent;



@Override

public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);

    setContentView(R.layout.main);

    

    mLocationClient = new LocationClient(this.getApplicationContext());

    

    mBDLocationListener = new MyBDLocationListener();

    mLocationClient.registerLocationListener(mBDLocationListener);

    

    LocationClientOption option = new LocationClientOption();

   

    // 需要地址信息,设置为其他任何值(string类型,且不能为null)时,都表示无地址信息。

    option.setAddrType("all");

    // 设置是否返回POI的电话和地址等详细信息。默认值为false,即不返回POI的电话和地址信息。 

    option.setPoiExtraInfo(true);

    

    // 设置产品线名称。强烈建议您使用自定义的产品线名称,方便我们以后为您提供更高效准确的定位服务。 

    option.setProdName("通过GPS定位我当前的位置");

    

    // 打开GPS,使用gps前提是用户硬件打开gps。默认是不打开gps的。 

    option.setOpenGps(true);

    

    // 定位的时间间隔,单位:ms

    // 当所设的整数值大于等于1000(ms)时,定位SDK内部使用定时定位模式。

    // option.setScanSpan(1000);

    

    // 查询范围,默认值为500,即以当前定位位置为中心的半径大小。

    option.setPoiDistance(500);

    // 禁用启用缓存定位数据

    option.disableCache(true);

    

    // 坐标系类型,百度手机地图对外接口中的坐标系默认是bd09ll

    option.setCoorType("bd09ll");

    

    // 设置最多可返回的POI个数,默认值为3。由于POI查询比较耗费流量,设置最多返回的POI个数,以便节省流量。

    option.setPoiNumber(3);

    

    // 设置定位方式的优先级。

    // 当gps可用,而且获取了定位结果时,不再发起网络请求,直接返回给用户坐标。这个选项适合希望得到准确坐标位置的用户。如果gps不可用,再发起网络请求,进行定位。

    option.setPriority(LocationClientOption.GpsFirst);

    

    mLocationClient.setLocOption(option);

  

    mContent = (TextView) this.findViewById(R.id.tv_content);

    

    // 发起定位请求

    findViewById(R.id.btn_request).setOnClickListener(new View.OnClickListener() {

		

		@Override

		public void onClick(View v) {

			 mLocationClient.start();

		}

	});

    

    

    // 重新定位

     findViewById(R.id.btn_location).setOnClickListener(new View.OnClickListener() {

		

		@Override

		public void onClick(View v) {

			

			if (mLocationClient != null && mLocationClient.isStarted())

			  mLocationClient.requestLocation();

		}

	});

    

     // 发起查询请求

     findViewById(R.id.btn_address).setOnClickListener(new View.OnClickListener() {

		

		@Override

		public void onClick(View v) {

			

			if (mLocationClient != null && mLocationClient.isStarted())

				mLocationClient.requestPoi();

		}

	}); 

    

}





final class MyBDLocationListener implements BDLocationListener{



	@Override

	public void onReceiveLocation(BDLocation location) {

		Log.e(TAG, "---------onReceiveLocation()---------");

		

		if(location == null){

			Log.e(TAG, "---------onReceiveLocation------location is NULL----");

			return;

		}

		

		int type = location.getLocType();

		Log.i(TAG, "当前定位采用的类型是:type = " + type);

		

		String coorType = location.getCoorType();

		Log.i(TAG, "坐标系类型:coorType = " + coorType);

		

		   // 判断是否有定位精度半径

        if(location.hasRadius()){

        	// 获取定位精度半径,单位是米

        	float accuracy = location.getRadius();

        	Log.i(TAG, "accuracy = " + accuracy);

        }

		

        if(location.hasAddr()){

			// 获取反地理编码。 只有使用网络定位的情况下,才能获取当前位置的反地理编码描述。

			String address = location.getAddrStr();

			Log.i(TAG, "address = " + address);

		}

        

        String province = location.getProvince();  // 获取省份信息

        String city = location.getCity();  // 获取城市信息

        String district = location.getDistrict(); // 获取区县信息

        

        Log.i(TAG, "province = " + province);

        Log.i(TAG, "city = " + city);

        Log.i(TAG, "district = " + district);

        

        double latitude = location.getLatitude();

        double longitude = location.getLongitude();

        Log.i(TAG, "latitude = " + latitude);

        Log.i(TAG, "longitude = " + longitude);

		

        

        StringBuffer sb = new StringBuffer(256);

		sb.append("time : ");

		sb.append(location.getTime());

		sb.append("\nerror code : ");

		sb.append(location.getLocType());

		sb.append("\nlatitude : ");

		sb.append(location.getLatitude());

		sb.append("\nlontitude : ");

		sb.append(location.getLongitude());

		sb.append("\nradius : ");

		sb.append(location.getRadius());

		if (location.getLocType() == BDLocation.TypeGpsLocation){

			sb.append("\nspeed : ");

			sb.append(location.getSpeed());

			sb.append("\nsatellite : ");

			sb.append(location.getSatelliteNumber());

		} else if (location.getLocType() == BDLocation.TypeNetWorkLocation){

尾声

如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

PS:之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

架构篇

《Jetpack全家桶打造全新Google标准架构模式》

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-nbUvYLUI-1715811234299)]

架构篇

《Jetpack全家桶打造全新Google标准架构模式》
[外链图片转存中…(img-ICcsrVIr-1715811234299)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 11
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值