拖动放置在UIStackView

时间:2016-03-04 22:10:21

标签: ios swift 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
}

1 个答案:

答案 0 :(得分:2)

布赖恩,

此代码执行我认为您希望执行的操作。显然你需要仔细检查它并更改变量名称,但我确定你可以接受它!

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
            }
        }
    }
}