在 iOS 開(kāi)發(fā)過(guò)程中,對(duì)圖片的處理不僅僅局限于顯示、渲染樣式,還常常遇到對(duì)view指定區(qū)域截圖,以及對(duì)圖片的壓縮、拉伸等操作。下面我們介紹一下類似的操作過(guò)程:

創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比舟曲網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式舟曲網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋舟曲地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴。
注:通過(guò) UIGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale) 和 drawViewHierarchyInRect 的配合來(lái)截取并渲染出來(lái)的圖片位置和大小,是由前者的size和后者的rect共同決定的。 即,畫(huà)布相當(dāng)于父view,其尺寸為size,截圖繪制到畫(huà)布中的位置和尺寸為rect。
想試一試的同學(xué),可以創(chuàng)建一個(gè)demo,取不同的size和rect值,來(lái)觀察畫(huà)布和截圖的位置。也可以試著將畫(huà)布和截圖完全吻合,即將截圖完整的渲染出來(lái),這并不難。
裁剪圖片就是對(duì)當(dāng)前的圖片按照指定的大小范圍生成一個(gè)新的圖片。需要注意的是如果當(dāng)前顯示圖片是2倍圖或者3倍圖,要么可能尺寸不對(duì),要么截出來(lái)的圖片很模糊,因此,需要在截圖前調(diào)整rect值。
注:UIImageJPEGRepresentation 兩個(gè)參數(shù):圖片引用 和壓縮系數(shù),而 UIImagePNGRepresentation 只需圖片引用作為參數(shù)。在實(shí)際使用過(guò)程中,UIImagePNGRepresentation(UIImage* image) 一般要比UIImageJPEGRepresentation(UIImage* image, 1.0) 返回的圖片數(shù)據(jù)量大,在處理圖片時(shí),若對(duì)圖片質(zhì)量要求不高,則建議使用UIImageJPEGRepresentation,根據(jù)自己的實(shí)際使用場(chǎng)景設(shè)置壓縮系數(shù),進(jìn)一步降低圖片數(shù)據(jù)量大小。
在 = iOS 5.0 時(shí),UIImage的新方法可以處理圖片的拉伸問(wèn)題:
使用過(guò)程:
在 = iOS 6.0 時(shí),UIImage的新方法可以處理圖片的拉伸問(wèn)題:
使用過(guò)程:
參考文章:
根據(jù)指定的view截屏
UIImage *saveImg = [self createImg:self.bgImgView];
[self savePhotoWithImg:saveImg];
保存截圖到相冊(cè)
根據(jù)指定區(qū)域截圖
UIImage *saveImg = [self createImg:self.bgImgView andFrame:CGRectMake(100, 100, 100, 100)];
[self savePhotoWithImg:saveImg];
若是對(duì)帶有視頻播放的頁(yè)面截圖,不可用上述方法,會(huì)出現(xiàn)黑屏,可使用以下方法實(shí)現(xiàn)效果
訪問(wèn)相冊(cè)需在項(xiàng)目的info.plist中添加
最近在做一個(gè)監(jiān)聽(tīng)用戶屏幕截圖,編輯圖片的功能。順帶把功能抽出來(lái)作為小組件分享一下。
由于沒(méi)有太多時(shí)間,暫時(shí)支持的自定義比較少????
pod 'LMScreenshotHint'
Ios截圖的方法有很多:
1.進(jìn)入ios15輔助觸控更多選項(xiàng)頁(yè)面,使用截屏功能即可進(jìn)行截屏,打開(kāi)設(shè)備頁(yè),點(diǎn)擊觸控小球圖標(biāo),打開(kāi)“設(shè)備”功能頁(yè)。:點(diǎn)擊更多。在設(shè)備功能頁(yè)面,點(diǎn)擊“更多”選項(xiàng)。使用截屏功能截屏,在更多選項(xiàng)頁(yè),點(diǎn)擊截屏功能進(jìn)行截屏。
2.有home鍵的機(jī)型可以使用home鍵加電源鍵進(jìn)行截圖。沒(méi)有home鍵的機(jī)型可以使用音量鍵加電源鍵的方式截圖。
3.在輔助觸控中找到“自定頂層菜單”,在其中啟用截屏,就可以在頂層菜單中使用截圖了。
self.snapImageView = (UIImageView*) [self.view snapshotViewAfterScreenUpdates:true];(簡(jiǎn)單)
這個(gè)方法直接就可以獲取到截取的圖片,然后就可以用來(lái)實(shí)現(xiàn)設(shè)置相應(yīng)的內(nèi)容。
可參考的鏈接
標(biāo)題名稱:ios開(kāi)發(fā)截圖,ios關(guān)于手機(jī)截圖
本文地址:http://chinadenli.net/article27/dseosjj.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、品牌網(wǎng)站制作、標(biāo)簽優(yōu)化、品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站導(dǎo)航、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)