Swift/iOS - 截屏铺坞,長屏,拼圖洲胖,保存圖片到指定的相冊

注意

在iOS中訪問相冊济榨,首先我們得獲取用戶授權(quán),在iOS10之前不用再Info.plist寫參數(shù)绿映。
在iOS10 之后要自定義彈出的信息

Privacy - Photo Library Usage Description
Privacy - Camera Usage Description

獲取權(quán)限

    /// 獲取權(quán)限
    ///
    /// - Parameter accessBlock:  閉包回調(diào)
    func accessCameraAuthority(accessBlock:AccessBlock!)
    {
        let authStatus = AVCaptureDevice.authorizationStatus(forMediaType: AVMediaTypeVideo)
        if authStatus == AVAuthorizationStatus.notDetermined {
            // 請求授權(quán)
            AVCaptureDevice.requestAccess(forMediaType: AVMediaTypeAudio, completionHandler: { finish in
                if finish {
                    if (accessBlock) != nil
                    {
                        accessBlock(true)
                    }
                }
                else
                {
                    if (accessBlock) != nil
                    {
                        accessBlock(false)
                    }
                }
            })
        }
        else if authStatus == AVAuthorizationStatus.authorized
        {
            // 授權(quán)成功
            if (accessBlock) != nil
            {
                accessBlock(true)
            }
        }
        else
        {
            // 用戶拒絕授權(quán)
            if (accessBlock) != nil
            {
                accessBlock(false)
            }
        }
    }

當(dāng)返回true擒滑,我們就可以有訪問權(quán)限了。
在iOS中截屏的方法如下:

    /// 截屏
    ///
    /// - Parameters:
    ///   - view: 要截屏的view
    /// - Returns: 一個UIImage
    func cutImageWithView(view:UIView) -> UIImage
    {
        // 參數(shù)①:截屏區(qū)域  參數(shù)②:是否透明  參數(shù)③:清晰度
        UIGraphicsBeginImageContextWithOptions(view.frame.size, true, UIScreen.main.scale)
        view.layer.render(in: UIGraphicsGetCurrentContext()!)
        let image:UIImage = UIGraphicsGetImageFromCurrentImageContext()!
        UIGraphicsEndImageContext();
        return image;
    }

這個方法是獲取當(dāng)前view的內(nèi)容叉弦,size的大小要巧妙的設(shè)置丐一,比如你的view超出了看到的屏幕,你使用截圖下來卸奉,
就是一部分回事黑色的區(qū)域钝诚。你截取當(dāng)前能看到的颖御,就widow就可以了榄棵。
我們在使用很多APP的時候會截出很長的圖,這個時候我們就用巧取得方式來獲取潘拱,方法如下:

     /// 截屏
    ///
    /// - Parameters:
    ///   - view: 要截屏的view
    /// - Returns: 一個UIImage
    func cutFullImageWithView(scrollView:UIScrollView) -> UIImage
    {
        // 記錄當(dāng)前的scrollView的偏移量和坐標(biāo)
        let currentContentOffSet:CGPoint = scrollView.contentOffset
        let currentFrame:CGRect = scrollView.frame;
        
        // 設(shè)置為zero和相應(yīng)的坐標(biāo)
        scrollView.contentOffset = CGPoint.zero
        scrollView.frame = CGRect.init(x: 0, y: 0, width: scrollView.frame.size.width, height: scrollView.frame.size.height)
        
        // 參數(shù)①:截屏區(qū)域  參數(shù)②:是否透明  參數(shù)③:清晰度
        UIGraphicsBeginImageContextWithOptions(scrollView.contentSize, true, UIScreen.main.scale)
        scrollView.layer.render(in: UIGraphicsGetCurrentContext()!)
        let image:UIImage = UIGraphicsGetImageFromCurrentImageContext()!
        
        // 重新設(shè)置原來的參數(shù)
        scrollView.contentOffset = currentContentOffSet
        scrollView.frame = currentFrame
        
        UIGraphicsEndImageContext();
        
        return image;
    }

這里是保證他是scrllView疹鳄,來切換相應(yīng)的offset和frame,來截取屏幕芦岂。有一點(diǎn)要注意瘪弓,比如你的是tableView,下面的數(shù)據(jù)中的圖片沒有加載出來禽最,也是肯定不會顯示的腺怯。
接下來就是把截圖保存到相冊袱饭,下面是保存到系統(tǒng)相冊:

    func writeImageToAlbum(image:UIImage)
    {
        UIImageWriteToSavedPhotosAlbum(image, self, #selector(image(image:didFinishSavingWithError:contextInfo:)), nil)
    }
    
    func image(image: UIImage, didFinishSavingWithError error: NSError?, contextInfo:UnsafeRawPointer)
    {
        if let e = error as NSError?
        {
            print(e)
        }
        else
        {
            UIAlertController.init(title: nil,
                                   message: "保存成功!",
                                   preferredStyle: UIAlertControllerStyle.alert).show(self, sender: nil);
        }
    }

寫入到指定的相冊呛占,這里看到的是先寫入相冊虑乖,再移動到指定的相冊

       // 看有沒有指定的相冊
        let library = ALAssetsLibrary.init()
        let albumGroups = NSMutableArray()
        
        library.enumerateGroups(withTypes: ALAssetsGroupType(ALAssetsGroupAll), using:
            {
                oneGroup,pointer in
                albumGroups.add(oneGroup! as ALAssetsGroup)
        },
                                failureBlock:
            {
                error in
        })
        
        var haveCustomAlbum = false
        for albumGroup in albumGroups
        {
            let groupName:String = (albumGroup as! ALAssetsGroup).value(forProperty: ALAssetsGroupPropertyName) as! String
            print(groupName)
            if groupName == "指定相冊"
            {
                haveCustomAlbum = true
            }
        }

如果有指定相冊直接寫入沒有就去創(chuàng)建

// 這里是創(chuàng)建相冊
if !haveCustomAlbum
        {
            library.addAssetsGroupAlbum(withName: "指定相冊",
                                        resultBlock:
                {alAsetGroup in
                    if alAsetGroup != nil
                    {
                        print("創(chuàng)建相冊成功");
                    }
            },
                                        failureBlock:
                {error in
                    print("創(chuàng)建相冊失敗");
            })
        }

下面是寫入到指定的相冊,下面的image晾虑,group和library都是上面獲取到的

func writeImageToCustomAlbumFinish(image:UIImage,library:ALAssetsLibrary,alAsetGroup:ALAssetsGroup)
    {
        // 首先寫入到寫到相冊 這里也可以用PHPhotoLibrary來做
        library.writeImage(toSavedPhotosAlbum: image.cgImage, orientation:.up, completionBlock:
            { url,error in
                if (error != nil)
                {
                    // 取到asset
                    library.asset(for: url, resultBlock:
                        {
                            aAlAset in
                            if aAlAset != nil
                            {
                                // 添加到group
                                alAsetGroup.add(aAlAset)
                            }
                    },
                                  failureBlock:
                        {
                            error in
                    })
                }
        })
    }

拼圖

func combinTwoImage(image1:UIImage,image2:UIImage) -> UIImage
    {
        let width = max(image1.size.width, image2.size.width)
        let height = image1.size.height + image2.size.height
        let offScreenSize = CGSize.init(width: width, height: height)
        
        UIGraphicsBeginImageContext(offScreenSize);
        
        let rect = CGRect.init(x:0, y:0, width:width, height:image1.size.height)
        image1.draw(in: rect)
        
        let rect2 = CGRect.init(x:0, y:image1.size.height, width:width, height:image2.size.height)
        image1.draw(in: rect2)
        
        let image:UIImage = UIGraphicsGetImageFromCurrentImageContext()!
        
        UIGraphicsEndImageContext();
        
        return image;
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末疹味,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子帜篇,更是在濱河造成了極大的恐慌糙捺,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件笙隙,死亡現(xiàn)場離奇詭異洪灯,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)逃沿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進(jìn)店門婴渡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人凯亮,你說我怎么就攤上這事边臼。” “怎么了假消?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵柠并,是天一觀的道長。 經(jīng)常有香客問我富拗,道長臼予,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任啃沪,我火速辦了婚禮粘拾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘创千。我一直安慰自己缰雇,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布追驴。 她就那樣靜靜地躺著械哟,像睡著了一般。 火紅的嫁衣襯著肌膚如雪殿雪。 梳的紋絲不亂的頭發(fā)上暇咆,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼爸业。 笑死其骄,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的扯旷。 我是一名探鬼主播年栓,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼薄霜!你這毒婦竟也來了某抓?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤惰瓜,失蹤者是張志新(化名)和其女友劉穎否副,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體崎坊,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡备禀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了奈揍。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片曲尸。...
    茶點(diǎn)故事閱讀 39,688評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖男翰,靈堂內(nèi)的尸體忽然破棺而出另患,到底是詐尸還是另有隱情,我是刑警寧澤蛾绎,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布昆箕,位于F島的核電站,受9級特大地震影響租冠,放射性物質(zhì)發(fā)生泄漏鹏倘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一顽爹、第九天 我趴在偏房一處隱蔽的房頂上張望纤泵。 院中可真熱鬧,春花似錦镜粤、人聲如沸捏题。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽涉馅。三九已至归园,卻和暖如春黄虱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背庸诱。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工捻浦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留晤揣,地道東北人。 一個月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓朱灿,卻偏偏與公主長得像昧识,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子盗扒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評論 2 353

推薦閱讀更多精彩內(nèi)容