react-native-baidu-map

地图

百度地图的环境配置这里就不过多介绍,在简书里搜索react-native-baidu-map就一大堆。而且都写的不错,自愧不如。就不在这里写了。今天我们来聊聊react-native-baidu-map一些自己遇到的坑。

有些坑,issue是可以帮到你的。

之前项目中用到了百度地图。只是需要地位功能。因此我只是将环境配置放入。当然拉,在环境配置上,也遇到大大小小的问题。最大的坑就是上头只给了我一个key还是安卓的。而我的运行环境是mac机上。运行了老半天了,一直发现,地图无法显示。。。啊。多么痛的领悟。一定要有两个key一个安卓key,一个ioskey。很多人会在react-native-baidu-map遇到大大小小的问题。当然issue是可以帮助到你的。很多人会在issue上问问题。很多的问题,你可以找到答案和解决的方案。

有些坑,issue、baidu、google也帮不到你。

就好比项目中有这样的需求,改变指针也就是地图属性中的markers,然后让地图重新定位,定位之后访问接口,请求参数,得到离你附近最近的“building”。
自己造了一些假数据-需求如图所示:

QQ20170710-231307.gif

这是ios的显示效果,和预期的效果非常的相似,我以为我的功能就这么轻轻松松的实现,其实不然,在android上却遇到了一个巨大的坑。
android上会报错“Error while updating property 'markers' of a viewmanaged by:RCTBaiduMapView”大致是这样的。说的是在更新组件markers的时候RCTBaiduMapView这里控制不了这个marker。尝试了一下午,也看了很多他人写的,基本都是跑demo。也在issue,当然拉,也没得到回复。我就想,是不是在改变marker的时候一定要带着其他的参数一起呢。
果不其然。

总结如下

  1. 不要在this.state 里定义 center marker 和 markers。
  2. 在给到marker进行setState的时候需要带入参数,center和zoom。
  3. geocode(city,address)方法是通过传入参数得到经纬度,这里的经纬度是string类型。而需要的参数是num类型,需要通过parseFloat()的方法转化一下。如果需要精确到多少位,也可以使用NumObject.toFixed()方法。
  4. 前两点在android的时候需要特别注意。
  this.state = {
        mayType: MapTypes.NORMAL,
        zoom: 15,
        trafficEnabled: false,
        baiduHeatMapEnabled: false,
       
    };

在componentWillMount()方法里获取并且定义地址。

componentWillMount(){
    var promise = Geolocation.geocode(city,address).then((data)=>{

        this.setState({
            zoom:18,
            markers:[
                {
                    longitude:parseFloat(data.longitude),
                    latitude:parseFloat(data.latitude),
                    title:'当前位置',
                }
            ],
            center:{
                longitude:parseFloat(data.longitude),
                latitude:parseFloat(data.latitude)
            },
        }).catch((error)=>{console.log(error)})}

在render里。通过点击 ,实现标志点的移动和重定位。

                <MapView
                trafficEnabled={this.state.trafficEnabled}
                baiduHeatMapEnabled={this.state.baiduHeatMapEnabled}
                zoom={this.state.zoom}
                mapType={this.state.mapType}
                center={this.state.center}
                markers={this.state.markers}
                style={styles.map}
                //点击获得当前的地址。
                onMapClick={(e)=>{
                    let json = JSON.stringify(e);
                    this.setState({
                        zoom:15,                    
                        markers:[
                            {
                                longitude:e.longitude ,
                                latitude: e.latitude,
                                title:'当前位置',
                            }
                        ],
                        center:{
                            longitude:e.longitude ,
                            latitude: e.latitude,
                        },
                    })
                    let param = {
                        longitude:e.longitude ,
                        latitude: e.latitude,
                    }
                    DeviceEventEmitter.emit('krislee',param);
                }}

            >
            </MapView>

地图这个功能不管在web还是app都是非常需要下功夫去好好研究的东西。之后有什么分享的,我也会写出一起分享。有不对的地方,希望大神可以指点出来。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,056评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,842评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,938评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,296评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,292评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,413评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,824评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,493评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,686评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,502评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,553评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,281评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,820评论 3 305
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,873评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,109评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,699评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,257评论 2 341

推荐阅读更多精彩内容