iOS開(kāi)發(fā)之如何截圖and如何合并多張圖片——Swift 版

一楚午、截圖

以下截圖代碼默認(rèn)使用UIGraphicsBeginImageContext踪古,圖片會(huì)有點(diǎn)失真或模糊祖灰,如需截圖的像素和View一樣钟沛,請(qǐng)使用

 // 第一個(gè)參數(shù)表示區(qū)域大小。第二個(gè)參數(shù)表示是否是非透明的局扶。如果需要顯示半透明效果恨统,需要傳NO,否則傳YES三妈。第三個(gè)參數(shù)就是屏幕密度了
UIGraphicsBeginImageContextWithOptions(size, false, UIScreen.main.scale())

1畜埋、UIView截圖

func capture(_ theView: UIView) -> UIImage {
    var rect = theView.frame
    if (theView is UIScrollView) {
        rect.size = (theView as! UIScrollView).contentSize
    }
    UIGraphicsBeginImageContext(rect.size)
    var context = UIGraphicsGetCurrentContext()!
    theView.layer.render(inContext: context)
    var img = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()
    return img
}

2、UIScrollview截圖

func capture(_ scrollView: UIScrollView) -> UIImage {
    var image: UIImage? = nil
    UIGraphicsBeginImageContext(scrollView.contentSize)
    do {
        var savedContentOffset = scrollView.contentOffset
        var savedFrame = scrollView.frame
        scrollView.contentOffset = .zero
        scrollView.frame = CGRect(x: 0, y: 0, width: scrollView.contentSize.width, height: scrollView.contentSize.height)
        scrollView.layer.render(inContext: UIGraphicsGetCurrentContext()!)
        image = UIGraphicsGetImageFromCurrentImageContext()
        scrollView.contentOffset = savedContentOffset
        scrollView.frame = savedFrame
    }
    UIGraphicsEndImageContext()
    if image != nil {
        return image
    }
    return nil
}

3畴蒲、合并多張圖片


func compose(withHeader header: UIImage, content: UIImage, footer: UIImage) -> UIImage {
    var size = CGSize(width: content.size.width, height: header.size.height + content.size.height + footer.size.height)
    UIGraphicsBeginImageContext(size)
    header.draw(in: CGRect(x: 0, y: 0, width: header.size.width, height: header.size.height))
    content.draw(in: CGRect(x: 0, y: header.size.height, width: content.size.width, height: content.size.height))
    footer.draw(in: CGRect(x: 0, y: header.size.height + content.size.height, width: footer.size.width, height: footer.size.height))
    var image = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()
    return image
}

二悠鞍、流媒體

將音頻、圖片轉(zhuǎn)成base64Binary

class func base64Encoded(_ data: Data) -> Data {
        //base64binary(流媒體)
    var encodingTable = ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "+", "/"]
    let bytes: UInt8 = data.bytes
    var result = String(capacity: data.length)
    var ixtext = 0
    var lentext = data.length
    var ctremaining = 0
    var inbuf = [UInt8](repeating: 0, count: 3)
    var outbuf = [UInt8](repeating: 0, count: 4)
    var i: UInt16 = 0
    var charsonline: UInt16 = 0
    var ctcopy: UInt16 = 0
    var ix = 0
    while true {
        ctremaining = lentext - ixtext
        if ctremaining <= 0 {

        }
        for i in 0..<3 {
            ix = ixtext + i
            if ix < lentext {
                inbuf[i] = bytes[ix]
            }
            else {
                inbuf[i] = 0
            }
        }
        outbuf[0] = (inbuf[0] & 0xFC) >> 2
        outbuf[1] = ((inbuf[0] & 0x03) << 4) | ((inbuf[1] & 0xF0) >> 4)
        outbuf[2] = ((inbuf[1] & 0x0F) << 2) | ((inbuf[2] & 0xC0) >> 6)
        outbuf[3] = inbuf[2] & 0x3F
        ctcopy = 4
        switch ctremaining {
            case 1:
                ctcopy = 2
            case 2:
                ctcopy = 3
        }

        for i in 0..<ctcopy {
            result += "\\\\(encodingTable[outbuf[i]])"
        }
        for i in ctcopy..<4 {
            result += "="
        }
        ixtext += 3
        charsonline += 4
    }
    return result.data(usingEncoding: String.Encoding.utf8)!
}

這里調(diào)用上面的方法

class func loadingFile(_ filepath: URL) -> String {
    var data = Data(contentsOf: filepath)
    var base64Data = self.base64Encoded(data)
    var strBase64 = String(base64Data, encoding: String.Encoding.ascii)
    return strBase64
    //you can upload this base64Data to server now
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末模燥,一起剝皮案震驚了整個(gè)濱河市咖祭,隨后出現(xiàn)的幾起案子掩宜,更是在濱河造成了極大的恐慌,老刑警劉巖心肪,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锭亏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡硬鞍,警方通過(guò)查閱死者的電腦和手機(jī)慧瘤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)固该,“玉大人锅减,你說(shuō)我怎么就攤上這事》セ担” “怎么了怔匣?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)桦沉。 經(jīng)常有香客問(wèn)我每瞒,道長(zhǎng),這世上最難降的妖魔是什么纯露? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任剿骨,我火速辦了婚禮,結(jié)果婚禮上埠褪,老公的妹妹穿的比我還像新娘浓利。我一直安慰自己,他們只是感情好钞速,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布贷掖。 她就那樣靜靜地躺著,像睡著了一般渴语。 火紅的嫁衣襯著肌膚如雪苹威。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天驾凶,我揣著相機(jī)與錄音屠升,去河邊找鬼。 笑死狭郑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的汇在。 我是一名探鬼主播翰萨,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼糕殉!你這毒婦竟也來(lái)了亩鬼?” 一聲冷哼從身側(cè)響起殖告,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雳锋,沒(méi)想到半個(gè)月后黄绩,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡玷过,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年爽丹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片辛蚊。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡粤蝎,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出袋马,到底是詐尸還是另有隱情初澎,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布虑凛,位于F島的核電站碑宴,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏桑谍。R本人自食惡果不足惜延柠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望霉囚。 院中可真熱鬧捕仔,春花似錦、人聲如沸盈罐。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)盅粪。三九已至钓葫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間票顾,已是汗流浹背础浮。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奠骄,地道東北人豆同。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像含鳞,于是被迫代替她去往敵國(guó)和親影锈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

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

  • WebSocket-Swift Starscream的使用 WebSocket 是 HTML5 一種新的協(xié)議。它實(shí)...
    香橙柚子閱讀 23,869評(píng)論 8 183
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)鸭廷、插件枣抱、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,105評(píng)論 4 62
  • 大寶:牛牛(7周歲5個(gè)月14天) 二寶:申申(10個(gè)月8天) 今天晚上學(xué)而思上課,讀經(jīng)中斷一天辆床。
    牛牛的豬媽閱讀 300評(píng)論 0 0
  • 寫(xiě)作起源于我想記錄生活中的點(diǎn)滴佳晶,可以讓自己靜下心來(lái),享受閱讀完一本書(shū)的樂(lè)趣讼载,找到自己的觀點(diǎn)和體會(huì)的那一份喜悅轿秧。 現(xiàn)...
    3分鐘即興演講閱讀 486評(píng)論 1 3
  • 午夜的魂跨過(guò)歲月之門在燈火闌珊處黯然傷神時(shí)光的鐘逆流繁華成空在人海茫茫里默不作聲 南海以南 不可侵犯的權(quán)漠北以北 ...
    哲語(yǔ)細(xì)細(xì)閱讀 493評(píng)論 22 26