###前提・実現したいこと
swiftで画像の切り抜き処理を行いたいのですが、画像サイズによっては、切り抜きの座標と大きさが正しく指定できません。ご教授いただければ幸いです。
###該当のソースコード
override func viewDidLoad() { super.viewDidLoad() //testImage.jpgのサイズは 1020 × 1980 xcode内にリソースとして用意した画像です。 let imageView = UIImageView(image:UIImage(named: "testImage.jpg")) imageView.frame = CGRectMake(0,0,self.view.frame.width,self.view.frame.height) imageView.contentMode = .ScaleAspectFill imageView.userInteractionEnabled = true self.view.addSubview(imageView) //ドラッグして切り抜きの範囲を指定、切り抜き処理を行うためのGesture let panGesture = UIPanGestureRecognizer(target: self,action:#selector(ViewController.panFunc(_:))) imageView.addGestureRecognizer(panGesture) } var borderView = UIView() //切り抜き位置を可視化するためのview var startPoint:CGPoint = CGPointZero func panFunc(sender:UIPanGestureRecognizer){ if sender.state == .Began{ //ドラッグ開始 startPoint = sender.locationInView(sender.view) borderView.layer.borderWidth = 2.0 borderView.frame = CGRectMake(startPoint.x,startPoint.y,0,0) self.view.addSubview(borderView) } if sender.state == .Changed{ //ドラッグ中 let genzaiP = sender.locationInView(sender.view) var gpW = genzaiP.x - startPoint.x var gpH = genzaiP.y - startPoint.y if genzaiP.x < startPoint.x{ borderView.frame.origin.x = genzaiP.x gpW = startPoint.x - genzaiP.x } if genzaiP.y < startPoint.y{ borderView.frame.origin.y = genzaiP.y gpH = startPoint.y - genzaiP.y } borderView.frame.size = CGSizeMake(gpW, gpH) } if sender.state == .Ended{ var newheight:CGFloat! var newwidth:CGFloat! let targetImage = (sender.view as! UIImageView).image! if targetImage.size.height >= targetImage.size.width{ //高さの方が大きい newheight = sender.view!.frame.size.height newwidth=(targetImage.size.width / targetImage.size.height)*newheight } else{ //幅の方が大きい newwidth = sender.view!.frame.size.width; newheight=(targetImage.size.height/targetImage.size.width)*newwidth; } //scale算出 let scaleFor_W = CIImage(CGImage: targetImage.CGImage!).extent.width / newwidth let scaleFor_H = CIImage(CGImage: targetImage.CGImage!).extent.height / newheight //切り抜き let cripImageRef = CGImageCreateWithImageInRect(targetImage.CGImage, CGRectMake( borderView.frame.origin.x * scaleFor_W, borderView.frame.origin.y * scaleFor_H, borderView.frame.width * scaleFor_W, borderView.frame.height * scaleFor_H)) //uiimageに戻す let cripImage = UIImage(CGImage: cripImageRef!) //切り抜いたimageを表示 dispatch_async(dispatch_get_main_queue(),{() let testImage = UIImageView(frame:CGRectMake(0, 0, cripImage.size.width, cripImage.size.height)) testImage.image = cripImage //切り抜いたimageをタップすると消去するようにする。 let tapGesture = UITapGestureRecognizer(target: self,action:#selector(ViewController.tapFunc(_:))) testImage.addGestureRecognizer(tapGesture) testImage.userInteractionEnabled = true self.view.addSubview(testImage) }) } } //切り抜いた画像を消去する func tapFunc(sender:UITapGestureRecognizer){ sender.view!.removeFromSuperview() }
###補足情報(言語/FW/ツール等のバージョンなど)
swift2 iOS9
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/06/10 15:05