拖动放置在 UIStackView 上的项目

Drag items placed on UIStackView

我有下面的代码,需要拖动视图以便重新定位。然而,在拖动时,视图就消失了。如何使位于堆栈视图顶部的视图可拖动?

堆栈视图:

let sView = UIStackView()
    sView.axis = UILayoutConstraintAxis.Vertical
    sView.distribution = .FillEqually
    sView.alignment = UIStackViewAlignment.Center
    sView.spacing = 15
    sView.backgroundColor = UIColor.redColor()
    sView.addArrangedSubview(view1)
    sView.addArrangedSubview(view2)
    sView.addArrangedSubview(view3)
    sView.layoutMarginsRelativeArrangement = true
    sView.translatesAutoresizingMaskIntoConstraints = false
    self.view.addSubview(sView)
    sView.centerXAnchor.constraintEqualToAnchor(self.view.centerXAnchor).active = true
    sView.centerYAnchor.constraintEqualToAnchor(self.view.centerYAnchor).active = true

观点; view1view2view3 的代码类似如下:

let view1 = UIView()
    view1.frame = CGRectMake(30, 50, 50, 80)
    view1.backgroundColor = UIColor.blueColor()
    view1.layer.cornerRadius = 6
    let gesture = UIPanGestureRecognizer(target: self, action: Selector("draggedView:"))
    view1.addGestureRecognizer(gesture)
    view1.userInteractionEnabled = true
    view1.tag = 1
    view1.heightAnchor.constraintEqualToConstant(85).active = true
    view1.widthAnchor.constraintEqualToConstant(55).active = true

draggedView函数:

func draggedView(gesture: UIPanGestureRecognizer){ 
    let loc = gesture.locationInView(self.view)
    let gesturedView = gesture.view
    gesturedView!.center = loc
}

布莱恩,

这段代码可以满足您的要求。显然你需要仔细检查并更改变量名,但我相信你能做到!

func draggedView(sender: UIPanGestureRecognizer) {
    if (sender.state == UIGestureRecognizerState.Began) {
        self.source = editorSVB!.arrangedSubviews.indexOf(sender.view!)! as Int
    }
    if (sender.state == UIGestureRecognizerState.Changed) {
        center = sender.view?.center
        let translation = sender.translationInView(sender.view)
        center = CGPointMake(center!.x + translation.x, center!.y + translation.y)
        sender.view?.center = center!
        sender .setTranslation(CGPointZero, inView: sender.view)
    }
     for blah in self.editorSVB!.arrangedSubviews {
        let no = blah.frame.intersect((sender.view?.frame)!)
        if (!no.origin.x.isInfinite) {
             self.object = editorSVB!.arrangedSubviews.indexOf(blah)! as Int
             if (self.object != self.source) {
                print("self,object, self.object",self,object, self.source)
                self.executable = self.object
            }
        }
    }
}