最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 腾讯位置服务地图SDK公交路线规划应用示例2

    正文概述 掘金(腾讯位置服务)   2020-12-18   653

    前言

    继续上一次的Demo,本次添加了同一路线的多条不同的公交线路展示,默认显示第0条。并且通过点击公交路线来切换选中的路线。

    上篇参考:腾讯位置服务地图SDK公交路线规划应用示例

    使用场景

    公交路线规划

    准备

    腾讯位置服务iOS地图SDK

    路线切换

    1、创建QPolyline的子类,用于区分步行部分和公交部分。

    @interface RoutePlanWalkingPolyline : QPolyline
    
    @end
    
    @interface RoutePlanBusingPolyline : QPolyline
    
    // 判断当前路线是否已经被选中
    @property (nonatomic, assign) BOOL isSelected;
    
    @end
    

    2、在创建路线Mode时,通过判断路线的种类来创建不同的模型,并且默认选中第0条路线。

    /*
     1. 默认选择第一个公交车线路
     2. 当前公交车线路 alpha = 1,有箭头
     3. 备用公交车线路 alpha = 0.5, 无箭头
     4. 点击备用公交车线路可以切换
     */
    // 驾车蚯蚓线
    // 遍历所有驾车路线
    for (int i = 0; i < plan.lines.count; i++) {
        QMSBusingRouteTransitLine *line = plan.lines[i];
        CLLocationCoordinate2D coords[line.polyline.count];
        
        for (int i = 0; i < line.polyline.count; i++) {
            NSValue *value = line.polyline[i];
            CLLocationCoordinate2D coord = [value coordinateValue];
            coords[i] = coord;
        }
        
        RoutePlanBusingPolyline *busPolyline = [[RoutePlanBusingPolyline alloc] initWithCoordinates:coords count:line.polyline.count];
        busPolyline.isSelected = i==0 ? YES : NO;
        [self.mapView addOverlay:busPolyline];
        [self.selectRouteOverlayArray addObject:busPolyline];
    }
    

    3、在添加折线视图时,额外添加判断当前的公交模型是否已经被选中的步骤。

    RoutePlanBusingPolyline *busingPolyline = (RoutePlanBusingPolyline *)overlay;
    // 路线箭头
    if (busingPolyline.isSelected) {
        
        polylineView.strokeColor = [UIColor colorWithRed:1 green:0 blue:0 alpha:0.5];
        polylineView.drawSymbol = YES;
        polylineView.zIndex = 1;
    } else {
        polylineView.strokeColor = [UIColor colorWithRed:0 green:0 blue:1 alpha:0.5];
        polylineView.drawSymbol = NO;
        polylineView.zIndex = 0;
    }
    

    4、最后,监听Overlay的点击方法,并判断回调的Overlay是否为公交路线的数据模型,然后选中该模型,取消选中其他的模型。

    - (void)mapView:(QMapView *)mapView didTapOverlay:(id<QOverlay>)overlay {
        // 判断是否是路线
        if ([overlay isKindOfClass:[RoutePlanBusingPolyline class]]) {
            
            for (QPolyline *polyline in self.selectRouteOverlayArray) {
                if ([polyline isKindOfClass:[RoutePlanBusingPolyline class]]) {
                    
                    RoutePlanBusingPolyline *busingPolyline = (RoutePlanBusingPolyline *)polyline;
                    
                    QTexturePolylineView *polylineView = (QTexturePolylineView *)[self.mapView viewForOverlay:busingPolyline];
    
                    if (busingPolyline == overlay) {
                        // 选中:实心颜色
                        busingPolyline.isSelected = YES;
                        polylineView.strokeColor = [UIColor colorWithRed:1 green:0 blue:0 alpha:0.5];
                        polylineView.zIndex = 1;
                        polylineView.drawSymbol = YES;
                    } else {
                        // 未选中:虚色
                        busingPolyline.isSelected = NO;
                        polylineView.strokeColor = [UIColor colorWithRed:0 green:0 blue:1 alpha:0.5];
                        polylineView.zIndex = 0;
                        polylineView.drawSymbol = NO;
                    }
                }
            }
        }
    }
    

    示例图

    腾讯位置服务地图SDK公交路线规划应用示例2

    腾讯位置服务地图SDK公交路线规划应用示例2


    起源地下载网 » 腾讯位置服务地图SDK公交路线规划应用示例2

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元