iOS 进阶

高德地图 自定义大头针效果

2020-06-17  本文已影响0人  何康老鬼

最近开发中遇到个需求,自定义大头针,记录一下自己在开发的过程中遇到的问题和解决的思路,以供在以后的开发的过程中学习!

0.先看看效果

截屏2020-06-17 上午9.10.04.png

1.配置高德

这个不用详细介绍了吧,自己去官方文档配置下,超简单的,主要是pod几个库,
看你们的需求,需要什么导入什么我这边导入这两个:
#高德地图搜索
pod 'AMapSearch'
pod 'AMap3DMap'

2.显示地图 获取数据

        private lazy var mapView:MAMapView = {[unowned self] in
            let mapView = MAMapView(frame: self.view.bounds)
            mapView.delegate = self
            mapView.showsUserLocation = true
            mapView.userTrackingMode = .follow
            mapView.isZoomEnabled = true
            mapView.zoomLevel = 13
          //显示比例尺 及位置
            mapView.showsScale = true
            mapView.scaleOrigin = CGPoint(x: WMRatio(20), y: WMRatio(100))
         //设置自定义位置精度圈
            mapView.customizeUserLocationAccuracyCircleRepresentation = true
            return mapView
            }()
           for item in users {
                let annation = myAnnotation()
                let latDouble = item.lat?.doubleValue
                let lngDouble = item.lng?.doubleValue
                annation.coordinate = CLLocationCoordinate2D(latitude: latDouble! , longitude: lngDouble!)
                annation.model = item
                self.arr.append(annation)
            }
            mapView.addAnnotations(arr)

3.实现地图代理方法

在创建完数据的时候用这个去移除自身定位的大头针的数据,没有作用
 mapView.removeAnnotation(self.mapView.userLocation)
最终还是在代理方法中去设置自身定位的图片为空的实现的(本来我是拒绝的....)
 func mapView(_ mapView: MAMapView!, viewFor annotation: MAAnnotation!) -> MAAnnotationView! {
        
        if annotation.isKind(of: MAUserLocation.self) {
            //去掉定位的图片
            let identifier = "item1"
            var annotationView =  mapView.dequeueReusableAnnotationView(withIdentifier: identifier)
            if annotationView == nil {
                annotationView = MAPinAnnotationView(annotation: annotation, reuseIdentifier: identifier)
            }
            annotationView?.image = UIImage(named: "")
            return annotationView
        }
        if annotation.isKind(of: MAPointAnnotation.self) {
           //自定义一个大头针的数据
            let identifier = "item"
            var annotationView = mapView.dequeueReusableAnnotationView(withIdentifier: identifier) as? WMDreamSquareViewController.DreamMapView.customAnnotationView
            if annotationView == nil {
            annotationView = customAnnotationView(annotation: annotation, reuseIdentifier: identifier)
            }
            annotationView?.annotation = annotation// 重要
            annotationView?.canShowCallout = false// 设置弹框
            let ata = annotation as? WMDreamSquareViewController.myAnnotation
            annotationView?.dataModel = ata?.model
            return annotationView
            
        }
        return nil
    }

    //MARK:大头针点击事件
    func mapView(_ mapView: MAMapView!, didSelect view: MAAnnotationView!)
    {
        mapView.deselectAnnotation(view.annotation, animated: true)
        let ata = view.annotation as? WMDreamSquareViewController.myAnnotation
        self.didAnnationViewBlock!(ata!.model!)
    }
     //MARK:缩放回调 用于刷新数据,因为不可能一次性在界面上请求所有数据,所以我想了下叫后台接收一个我返回的距离给他 主要计算的方式是在指定的缩放级别下, 基于地图中心点, 1 screen point 对应的距离(单位是米)*屏幕的宽度 
    func mapView(_ mapView: MAMapView!, mapDidZoomByUser wasUserAction: Bool) {
     
        let unit = CGFloat(mapView.metersPerPoint(forZoomLevel: mapView.zoomLevel)) * iphone.width
        print("2=======\(mapView.zoomLevel)============\(CGFloat(mapView.metersPerPoint(forZoomLevel: mapView.zoomLevel)))--\(iphone.width)----\(unit)")
        self.touchZoomRefreshBlock!(Int(ceil(unit)))
        
    }

4.自定义大头针试图

 //MARK:继承MAAnnotationView来创建一个自己的大头针视图
    class customAnnotationView:MAAnnotationView {
        
      private  lazy var bgImageView:UIImageView = {
            let view = UIImageView()
            view.contentMode = .scaleAspectFit
            view.image = UIImage(named: "椭圆45")
            view.isUserInteractionEnabled = true
            return view
        }()
        
      private  lazy var headView:UIImageView = {
            let view = UIImageView()
            view.layer.cornerRadius = WMRatio(17.5)
            view.layer.masksToBounds = true
            view.backgroundColor = UIColor.clear
            return view
        }()
        
        
        var dataModel: WMDreamSquareViewController.User?{
            didSet {
                guard let dataModel = dataModel else {
                    return
                }
                
                
                bgImageView.image = (dataModel.type?.stringValue == "1") ? UIImage(named: "xygc_tx_bg_r") : UIImage(named: "xygc_tx_bg_y")
                headView.yy_setImage(with: URL(string: dataModel.avatar_url!.stringValue), placeholder: UIImage(named: "face"))
            }
            
        }
        
        
        override init!(annotation: MAAnnotation!, reuseIdentifier: String!) {
            super.init(annotation: annotation, reuseIdentifier: reuseIdentifier)
            //这里需要设置一个大小要不然点击响应不了
            self.bounds = CGRect(x: 0, y: 0, width: WMRatio(45), height: WMRatio(45))
            addSubview(bgImageView)
            bgImageView.addSubview(headView)
            
            bgImageView.layoutSubviews()
            bgImageView.snp.makeConstraints { (make) in
                make.centerX.centerY.equalToSuperview()
                make.width.height.equalTo(WMRatio(45))
            }
            
            headView.snp.makeConstraints { (make) in
               make.centerX.equalToSuperview()
                make.centerY.equalTo(bgImageView).offset(-WMRatio(3))
                make.width.height.equalTo(WMRatio(35))
            }

        }
        
        override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
           let rect = self.convert(self.frame, from: self.superview)
          //print("point---------\(point)========rect------\(rect)*********self.frame------\(self.frame)")
           if rect.contains(point) {
               return self
           }else{
               return nil
           }
            
        }
        
       required init?(coder: NSCoder) {
            fatalError("init(coder:) has not been implemented")
        }
        
    }
    

5.扩展 还需要实现一个弹出的试图

 class DatouzhenView:WMView {
        
      private  lazy var bgView:UIView = {
            let view = UIView()
            view.layer.cornerRadius = WMRatio(10)
            view.layer.masksToBounds = true
            view.backgroundColor = UIColor.white
            return view
        }()
        ///头像
      private  lazy var headView:UIImageView = {
            let imageView = UIImageView()
            imageView.image = UIImage(named: "love")
            imageView.layer.cornerRadius = WMRatio(50)/2
            imageView.layer.masksToBounds = true
            return imageView
        }()
        ///昵称
      private  lazy var titleLabel:UILabel = {
            let label = UILabel()
            label.font = WMFont(14)
            label.text = "会飞的鱼"
            return label
        }()
        
        ///l年龄
        private  lazy var ageAdnSexButton: UIButton = {
            let view = UIButton()
            
            view.titleLabel?.font = WMFont(12)
            view.setImage(UIImage(named: "Fate_girl"), for: .normal)
            view.setImage(UIImage(named: "Fate_boy"), for: .selected)
            view.setTitleColor(UIColor.white, for: .normal)
            view.setBackgroundImage(UIImage(color: color("#FB5798")!), for: .normal)
            view.setBackgroundImage(UIImage(color: color("#5EA1FD")!), for: .selected)
            view.setTitle("12", for: .normal)
            view.titleEdgeInsets.left = 2.5
            view.imageEdgeInsets.left = -2.5
            view.layer.cornerRadius = 3
            view.clipsToBounds = true
            return view
        }()
        ///星座
        private  lazy var constellationButton: UIButton = {
            let view = UIButton()
            
            view.titleLabel?.font = WMFont(12)
            view.setTitleColor(UIColor.white, for: .normal)
            view.backgroundColor = WMColor("#F29600")
            view.setTitle("水瓶座", for: .normal)
            view.layer.cornerRadius = WMRatio(3)
            return view
        }()
        ///心愿
        private  lazy var xinyuanButton: UIButton = {
            let view = UIButton()
            view.titleLabel?.font = WMFont(12)
            view.setTitleColor(UIColor.white, for: .normal)
            view.backgroundColor = WMColor("#E8B916")
            view.setTitle("心愿", for: .normal)
            view.layer.cornerRadius = WMRatio(3)
            return view
        }()
        
        ///内容
        private lazy var contentLabel:YYLabel = {
            let view = YYLabel()
            view.text = "附近又好看的小姐姐吗?一起尝尝去"
            view.textColor = color("#333333")
            view.font = WMFont(14)
            return view
        }()
        
        ///套餐背景图
        private lazy var iconImageView:UIButton = {
            let view = UIButton()
            view.clipsToBounds = true
            view.contentMode = .scaleAspectFill
            view.layer.cornerRadius = WMRatio(10)
            view.layer.masksToBounds = true
            view.setImage(UIImage(named: "myCollection_img1"), for: .normal)
            view.imageView?.contentMode = .scaleAspectFill
            view.action(event: .touchUpInside) { (button) in
                self.router(event: Event.商品详情)
            }
            return view
        }()
        
        ///喜欢
        private lazy var likeButton:UIButton = {
            let view = UIButton()
            view.setImage(UIImage(named: "ShowMerchants_collection1"), for: .normal)
            //view.setTitle("0人", for: .normal)
            view.setTitleColor(color("#999999"), for: .normal)
            view.titleLabel?.font = WMFont(11)
            view.contentHorizontalAlignment = .right
            return view
        }()
        ///套餐名称和说明
        private lazy var nameLabel:YYLabel = {
            let view = YYLabel()
            view.text = "佐客优选双人套餐,提供免费WIFI"
            view.textColor = color("#333333")
            view.font = WMFont(15)
            return view
        }()
        ///时间/距离
        private lazy var remainingAndSoldLabel:YYLabel = {
            let view = YYLabel()
            view.text = "6小时前·2.6km·366人看过"
            view.textColor = color("#999999")
            view.font = WMFont(11)
            return view
        }()
        ///等待完成心愿
        private lazy var waitfinshLabel:YYLabel = {
            let view = YYLabel()
            view.text = "等待完成心愿"
            view.textColor = color("#FFFFFF")
            view.font = WMFont(12)
            return view
        }()
        ///价格
        private lazy var priceLabel:YYLabel = {
            let view = YYLabel()
            let att = NSMutableAttributedString()
            var temp = NSMutableAttributedString(string: "¥66")
            temp.yy_font = WMFont(16)
            temp.yy_color = color("#F14545")
            att.append(temp)
            att.yy_appendString(" ")
            temp = NSMutableAttributedString(string: "¥86")
            temp.yy_font = WMFont(12)
            temp.yy_color = color("#666666")
            temp.yy_strikethroughStyle = [.thick]
            att.append(temp)
            view.attributedText = att
            return view
        }()
        
        private  lazy var lineView:UIView = {
              let view = UIView()
             view.backgroundColor = color("#EEEEEE")
              return view
          }()
        
        
        ///打招呼
        private lazy var dazhaohuButton:UIButton = {
            let view = UIButton()
            view.setTitle("打招呼", for: .normal)
            view.setTitleColor(UIColor.white, for: .normal)
            view.titleLabel?.font = WMFont(16)
            view.backgroundColor = UIColor.redBackground
            view.layer.cornerRadius = WMRatio(20)
            view.layer.masksToBounds = true
            view.action(event: .touchUpInside) {[weak self] (button) in
                self?.router(event: Event.打招呼)
            }
            return view
        }()
        
        
        //MARK:数据赋值
        var dataModel:User?{
            didSet{
                guard let dataModel = dataModel else {
                    return
                }
                

                headView.yy_setImage(with: URL(string: dataModel.avatar!.stringValue), options: YYWebImageOptions(rawValue: 0))

                titleLabel.text = dataModel.nickname?.stringValue
                ageAdnSexButton.isSelected = dataModel.sex?.intValue == 0 ? true : false
                ageAdnSexButton.setTitle(dataModel.age?.stringValue, for: .normal)
                constellationButton.setTitle("水瓶座", for: .normal)
                xinyuanButton.setTitle(dataModel.type?.intValue == 0 ? "心愿" : "约会", for: .normal)
//                contentLabel.text = dataModel.content?.stringValue
//                iconImageView.setImage(UIImage(named: dataModel.goodsPic.stringValue), for: .normal)
//                nameLabel.text = dataModel.goodstitle?.stringValue
//                priceLabel.text = "¥ \(dataModel.price!)"
//                remainingAndSoldLabel.text = "\(dataModel.time!)·\(dataModel.distent!.stringValue)·\(dataModel.seepeoples!.stringValue)"
//                likeButton.setTitle(dataModel.loves?.stringValue, for: .normal)
                
            }
        }
        
        override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
            if (touches.first?.view?.isEqual(self))! {
                self.router(event: Event.空白)
            }
        }
        
        override func setUI() {
            
            backgroundColor = UIColor.clear
            
            layer.cornerRadius = 7.5
            clipsToBounds = true
            backgroundColor = color("#EEEEEE")
            addSubview(bgView)
            
            bgView.addSubview(headView)
            bgView.addSubview(titleLabel)
            bgView.addSubview(ageAdnSexButton)
            bgView.addSubview(constellationButton)
            bgView.addSubview(xinyuanButton)
            bgView.addSubview(contentLabel)
            bgView.addSubview(iconImageView)
            bgView.addSubview(remainingAndSoldLabel)
            bgView.addSubview(likeButton)
            bgView.addSubview(nameLabel)
            bgView.addSubview(waitfinshLabel)
            bgView.addSubview(priceLabel)
            bgView.addSubview(lineView)
            bgView.addSubview(dazhaohuButton)
            
            
            bgView.snp.makeConstraints { (make) in
                make.centerX.centerY.equalToSuperview()
                make.width.equalTo(WMRatio(350))
                make.height.equalTo(WMRatio(400))
            }
            
            headView.snp.makeConstraints { (make) in
                make.top.equalTo(WMRatio(12))
                make.left.equalTo(WMRatio(12))
                make.height.width.equalTo(WMRatio(50))
            }
            
            titleLabel.snp.makeConstraints { (make) in
                make.left.equalTo(headView.snp.right).offset(WMRatio(8))
                make.top.equalTo(headView.snp.top)
                make.right.equalToSuperview().offset(-WMRatio(12))
            }
            
            ageAdnSexButton.snp.makeConstraints { (make) in
                make.left.equalTo(headView.snp.right).offset(WMRatio(5))
                make.top.equalTo(titleLabel.snp.bottom).offset(WMRatio(5))
                make.width.equalTo(WMRatio(43))
                make.height.equalTo(WMRatio(16))
            }
            constellationButton.snp.makeConstraints { (make) in
                make.centerY.equalTo(ageAdnSexButton)
                make.left.equalTo(ageAdnSexButton.snp.right).offset(WMRatio(5))
                make.width.equalTo(WMRatio(43))
                make.height.equalTo(WMRatio(16))
            }
            xinyuanButton.snp.makeConstraints { (make) in
                make.centerY.equalTo(ageAdnSexButton)
                make.left.equalTo(constellationButton.snp.right).offset(WMRatio(5))
                make.width.equalTo(WMRatio(43))
                make.height.equalTo(WMRatio(16))
            }
            
            
            contentLabel.snp.makeConstraints { (make) in
                make.left.equalTo(WMRatio(12))
                make.right.equalTo(-WMRatio(12))
                make.top.equalTo(headView.snp.bottom).offset(WMRatio(12))
            }
            
            iconImageView.snp.makeConstraints { (make) in
                make.left.equalTo(WMRatio(12))
                make.right.equalTo(-WMRatio(12))
                make.height.equalTo(WMRatio(140))
                make.top.equalTo(contentLabel.snp.bottom).offset(WMRatio(5))
            }
            
            
            dazhaohuButton.snp.makeConstraints { (make) in
                make.bottom.equalToSuperview().offset(-WMRatio(12))
                make.centerX.equalToSuperview()
                make.width.equalTo(WMRatio(150))
                make.height.equalTo(WMRatio(40))
            }
            
            likeButton.snp.makeConstraints { (make) in
                make.right.equalToSuperview().offset(-WMRatio(12))
                make.bottom.equalTo(dazhaohuButton.snp.top).offset(-WMRatio(12))
                make.width.height.equalTo(WMRatio(30))
            }
            
            
            remainingAndSoldLabel.snp.makeConstraints { (make) in
                make.left.equalTo(WMRatio(12))
                make.bottom.equalTo(dazhaohuButton.snp.top).offset(-WMRatio(12))
            }
            
            nameLabel.snp.makeConstraints { (make) in
                make.left.equalTo(WMRatio(12))
                make.top.equalTo(iconImageView.snp.bottom).offset(WMRatio(8))
            }
            
            priceLabel.snp.makeConstraints { (make) in
                make.left.equalTo(WMRatio(12))
                make.top.equalTo(nameLabel.snp.bottom).offset(WMRatio(5))
                
            }
            lineView.snp.makeConstraints { (make) in
                make.left.equalToSuperview().offset(WMRatio(5))
                make.right.equalToSuperview().offset(-WMRatio(5))
                make.height.equalTo(0.5)
                make.top.equalTo(priceLabel.snp.bottom).offset(WMRatio(8))
            }
            
            waitfinshLabel.snp.makeConstraints { (make) in
                make.right.equalTo(-WMRatio(12))
                make.centerY.equalTo(priceLabel)
            }
         
        }
        
    }

6.总结

在这个过程中遇到的两个问题1.就是关掉自身的大头针,除了去代理方法中设置空图片,我试了好多中其他的方式都实现不了2.点击大头针试图传值。开始没有想到继承,直接用系统的,一直带不过来数据,后面还想着用title做对比得到数据中的索引,但是这样做感觉太麻烦了,有点得不偿失!

上一篇 下一篇

猜你喜欢

热点阅读