簡體   English   中英

如何使用Swift 3.0使用單指同時旋轉和調整視圖大小

[英]How can i Rotate and Resize View at a time using Single finger using swift 3.0

我想一次在swift 3.0中使用單指旋轉和調整視圖大小,我在Objective-c中找到了很多解決方案,但是我陷入了將其轉換為swift的困境。 我已經使用以下代碼旋轉視圖

    let panRotateGesture = UIPanGestureRecognizer(target: self, action: #selector(self.rotateViewPanGesture))
    rotateView?.addGestureRecognizer(panRotateGesture)
    panRotateGesture.require(toFail: panRotateGesture)
    textView?.addSubview(rotateView!)

RotateViewPanGesture函數

func rotateViewPanGesture(_ recognizer: UIPanGestureRecognizer) {

    if recognizer.state == .began {

        deltaAngle = atan2(Float(recognizer.location(in: textView).y - textView!.center.y), Float(recognizer.location(in: textView).x - textView!.center.x))
        startTransform = (textView?.transform)!

    } else if recognizer.state == .changed {

        let ang: Float = atan2(Float(recognizer.location(in: textView!.superview).y - textView!.center.y), Float(recognizer.location(in: textView!.superview).x - textView!.center.x))
        let angleDiff: Float = deltaAngle - ang
        textView?.transform = CGAffineTransform(rotationAngle: -(CGFloat)(angleDiff))
        textView?.setNeedsDisplay()

    } else if recognizer.state == .ended {

        deltaAngle = atan2(Float(recognizer.location(in: textView).y - textView!.center.y), Float(recognizer.location(in: textView).x - textView!.center.x))
        startTransform = (textView?.transform)!
        textView?.setNeedsDisplay()

    }

}

在這里, textView是我要旋轉調整大小的視圖。

以下是我調整視圖大小的代碼

    func resizeViewPanGesture(_ recognizer: UIPanGestureRecognizer) {

        let translation = recognizer.translation(in: recognizer.view)

        if let view = recognizer.view {
            view.transform = (textView?.transform.translatedBy(x: translation.x, y: translation.y))!
        }

        recognizer.setTranslation(CGPoint.zero, in: recognizer.view)
    }

}

但這對我不起作用。 有人可以幫我這個忙,如何快速用一根手指一次旋轉和調整視圖大小3

我已經使用以下代碼解決了我的問題。 它幫助我用一根手指旋轉和調整圖像大小。

 func stickerResizeGesture(_ recognizer: UIPanGestureRecognizer) {

    let superview = recognizer.view?.superview

    stickerContainerView = superview

    for element in (superview?.subviews)! {

        if element.accessibilityHint == "Main Image" {
            imgSticker = element as! UIImageView
        }

        if element.accessibilityHint == "Delete" {
            deleteView = element as? UIImageView
        }

        if element.accessibilityHint == "Rotate" {
            rotateView = element as? UIImageView
        }

        if element.accessibilityHint == "Resize" {
            resizeView = element as? UIImageView
        }
    }

    let touchLocation = recognizer.location(in: stickerContainerView?.superview)

    let center = CalculateFunctions.CGRectGetCenter((stickerContainerView?.frame)!)

    if recognizer.state == .began {

        prevPoint = recognizer.location(in: stickerContainerView?.superview)


        //Rotate
        deltaAngle = Float(atan2(touchLocation.y - center.y, touchLocation.x - center.x) - CalculateFunctions.CGAffineTrasformGetAngle(self.startTransform))

        initialBounds = stickerContainerView?.bounds

        initialDistance = CalculateFunctions.CGpointGetDistance(center, point2: touchLocation)
        //stickerContainerView?.setNeedsDisplay()


    } else if recognizer.state == .changed {

        if (stickerContainerView?.bounds.size.width)! < CGFloat(100.0) {


            stickerContainerView?.bounds = CGRect(x: (stickerContainerView?.bounds.origin.x)!,
                                                  y: (stickerContainerView?.bounds.origin.y)!,
                                                  width: (stickerContainerView?.bounds.size.width)!,
                                                  height: (stickerContainerView?.bounds.size.width)!)

            imgSticker.frame = CGRect(x: 12,
                                      y: 12,
                                      width: (stickerContainerView?.bounds.size.width)! - (resizeView?.frame.width)!,
                                      height: (stickerContainerView?.bounds.size.height)! - (resizeView?.frame.height)!)

            resizeView?.frame = CGRect(x: (stickerContainerView?.bounds.size.width)! - (resizeView?.frame.width)!,
                                       y: (stickerContainerView?.bounds.size.height)! - (resizeView?.frame.height)!,
                                       width: (resizeView?.frame.width)!,
                                       height: (resizeView?.frame.height)!)


            rotateView?.frame = CGRect(x: 0,
                                       y: (stickerContainerView?.bounds.size.height)! - (rotateView?.frame.height)!,
                                       width: (rotateView?.frame.width)!,
                                       height: (rotateView?.frame.height)!)

            deleteView?.frame = CGRect(x: 0,
                                       y: 0,
                                       width: (deleteView?.frame.width)!,
                                       height: (deleteView?.frame.height)!)

        } else if (stickerContainerView?.bounds.size.height)! < CGFloat(100.0) {

            stickerContainerView?.bounds = CGRect(x: (stickerContainerView?.bounds.origin.x)!,
                                                  y: (stickerContainerView?.bounds.origin.y)!,
                                                  width: (stickerContainerView?.bounds.size.height)!,
                                                  height: (stickerContainerView?.bounds.size.height)!)


            imgSticker.frame = CGRect(x: 12, y: 12,
                                      width: (stickerContainerView?.bounds.size.width)! - (resizeView?.frame.width)!,
                                      height: (stickerContainerView?.bounds.size.height)! - (resizeView?.frame.height)!)

            resizeView?.frame = CGRect(x: (stickerContainerView?.bounds.size.width)! - (resizeView?.frame.width)!,
                                       y: (stickerContainerView?.bounds.size.height)! - (resizeView?.frame.height)!,
                                       width: (resizeView?.frame.width)!,
                                       height: (resizeView?.frame.height)!)

            rotateView?.frame = CGRect(x: 0, y: (stickerContainerView?.bounds.size.height)! - (rotateView?.frame.height)!,
                                       width: (rotateView?.frame.width)!,
                                       height: (rotateView?.frame.height)!)

            deleteView?.frame = CGRect(x: 0,
                                       y: 0,
                                       width: (deleteView?.frame.width)!,
                                       height: (deleteView?.frame.height)!)

        } else {

            let point: CGPoint = recognizer.location(in: stickerContainerView!.superview)

            let newHeight = (stickerContainerView?.bounds.size.width)! + CGFloat(point.y - prevPoint.y)
            let newWidth = (stickerContainerView?.bounds.size.height)! + CGFloat(point.y - prevPoint.y)

            if newHeight < CGFloat(100.0) && newWidth < CGFloat(100.0) {

                stickerContainerView?.bounds = CGRect(x: stickerContainerView!.bounds.origin.x,
                                                      y: stickerContainerView!.bounds.origin.y,
                                                      width: 100.0,
                                                      height: 100.0)


            } else {

                stickerContainerView?.bounds = CGRect(x: stickerContainerView!.bounds.origin.x,
                                                      y: stickerContainerView!.bounds.origin.y,
                                                      width: newWidth,
                                                      height: newHeight)

            }


            imgSticker.frame = CGRect(x: 12,
                                      y: 12,
                                      width: (stickerContainerView?.bounds.size.width)! - (resizeView?.frame.width)!,
                                      height: (stickerContainerView?.bounds.size.height)! - (resizeView?.frame.height)!)

            resizeView?.frame = CGRect(x: (stickerContainerView?.bounds.size.width)! - (resizeView?.frame.width)!,
                                       y: (stickerContainerView?.bounds.size.height)! - (resizeView?.frame.height)!,
                                       width: (resizeView?.frame.width)!,
                                       height: (resizeView?.frame.height)!)

            rotateView?.frame = CGRect(x: 0,
                                       y: (stickerContainerView?.bounds.size.height)! - 25,
                                       width: (rotateView?.frame.width)!,
                                       height: (rotateView?.frame.height)!)

            deleteView?.frame = CGRect(x: 0,
                                       y: 0,
                                       width: (deleteView?.frame.width)!,
                                       height: (deleteView?.frame.height)!)

            prevPoint = recognizer.location(in: stickerContainerView?.superview)

        }

        // Rotate

        let ang: Float = atan2(Float(touchLocation.y - center.y), Float(touchLocation.x - center.x))

        let angleDiff = deltaAngle - ang

        stickerContainerView?.transform = CGAffineTransform(rotationAngle: -(CGFloat)(angleDiff))
        stickerContainerView?.setNeedsDisplay()


    } else if recognizer.state == .ended {


        prevPoint = recognizer.location(in: stickerContainerView?.superview)

        //Rotate

        let ang: Float = atan2(Float(touchLocation.y - center.y), Float(touchLocation.x - center.x))
        startTransform = (stickerContainerView?.transform)!

        // stickerContainerView?.setNeedsDisplay()


    }

}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM