尝试为模态视图创建模糊背景的问题

时间:2015-09-11 13:39:42

标签: uiblureffect

我试图以模态显示视图。该视图显示为" Cross Dissolve" "全屏"。我正在将屏幕截图传递给控制器​​。然后我尝试裁剪屏幕截图并仅保留视图下方的部分。这我正在模糊并添加到视图中。

代码可以模糊,但我有两个问题。 1)图像是双倍尺度,这将与视网膜显示有关,但我不知道如何解决这个问题。 2)另一个是,尝试了我能想到的一切,我无法得到"画布的坐标#34;在一个帮助我正确裁剪视图的坐标系中。

我真的非常感谢这方面的帮助 谢谢 卡尔

    override func viewWillAppear(animated: Bool) {
    super.viewWillAppear(animated)

    let appDelegate = UIApplication.sharedApplication().delegate as! AppDelegate
    let window = appDelegate.window!
    let splitViewController = window.rootViewController as! UISplitViewController;

    let cropFrame = UIView().convertRect(self.canvas.frame, toView: splitViewController.view)

    let croppedScreenShotCG = CGImageCreateWithImageInRect(screenShot?.CGImage, cropFrame)
    let croppedScreenShot = UIImage(CGImage:croppedScreenShotCG)

    var blurEffect = UIBlurEffect(style: UIBlurEffectStyle.Light)
    var blurEffectView = UIVisualEffectView(effect: blurEffect)

    blurEffectView.frame = CGRectMake(0, 0, self.canvas.frame.width, self.canvas.frame.height)

    let blurImageView = UIImageView(image:croppedScreenShot)
    blurImageView.addSubview(blurEffectView)

    let blurColorCast = UIView(frame: CGRectMake(0, 0, self.canvas.frame.width, self.canvas.frame.height))
    blurColorCast.backgroundColor = UIColor.cloverColor10pc()
    blurColorCast.alpha = 0.2
    blurImageView.addSubview(blurColorCast)

    self.canvas.addSubview(blurImageView)
    self.canvas.sendSubviewToBack(blurImageView)

    UIImageWriteToSavedPhotosAlbum(croppedScreenShot, nil, nil, nil)
}

我的屏幕截图如下:

            let layer = window.layer
        let scale = UIScreen.mainScreen().scale
        UIGraphicsBeginImageContextWithOptions(layer.frame.size, false, scale);

        layer.renderInContext(UIGraphicsGetCurrentContext())
        let screenshot = UIGraphicsGetImageFromCurrentImageContext()
        UIGraphicsEndImageContext()

1 个答案:

答案 0 :(得分:0)

您可以使用CGImage:而不是使用UIImage的imageWithCGImage:scale:orientation:,它会使用比例参数来考虑视网膜屏幕。

请参阅:https://developer.apple.com/library/ios/documentation/UIKit/Reference/UIImage_Class/#//apple_ref/occ/clm/UIImage/imageWithCGImage:scale:orientation

但我个人更喜欢避免在代码中做任何事情,如果有合理的方法可以使用故事板。

这是一个example project,它对模式演示文稿的背面有一个模糊效果,根本不使用任何代码。

唯一值得注意的是,对于正在呈现的视图控制器,根视图背景颜色设置为清除(否则呈现它的视图控制器将被遮挡)。