iOS繪圖基礎(chǔ)(圖像相關(guān))

前篇地址:iOS繪圖基礎(chǔ)(圖形文字曲線相關(guān))

這篇主要是記錄記錄iOS繪圖與圖像有關(guān)的一些處理戚长。包括繪制圖片盗冷,裁剪圖片,給圖片增加水印等常用功能同廉。

繪制圖片

作為圖片來說仪糖,也有兩套方式去繪制圖片。UIKit的方式迫肖、CoreGraphics的API方式锅劝。

第一種:(非常快速)

- (void)drawRect:(CGRect)rect {
    /*  繪制圖片    */
    UIImage *image = [UIImage imageNamed:@"Vokie"];
    [image drawInRect:CGRectMake(10, 10, 100, 100)];
}

第二種:(稍顯復(fù)雜)

- (void)drawRect:(CGRect)rect {
    /*  繪制圖片    */
    CGRect imageRect = CGRectMake(10, -10, 100, 100);
    
    //獲取上線文context
    CGContextRef context = UIGraphicsGetCurrentContext();

    /*圖片繪制時(shí)的上下顛倒問題蟆湖,具體原因不明故爵,可能與底層的繪制API及其鏡像相關(guān),待深入研究隅津。
      所以做了下面的一次翻轉(zhuǎn)稠集,一次平移的操作來修正*/
    //翻轉(zhuǎn)context
    CGContextScaleCTM(context, 1, -1);
    //平移context
    CGContextTranslateCTM(context, 0, -imageRect.size.height);
    
    UIImage *cgImage = [UIImage imageNamed:@"Vokie"];
    //繪圖
    CGContextDrawImage(context, imageRect, cgImage.CGImage);
}

對(duì)第二種方法,稍開腦洞饥瓷。既然可以對(duì)context進(jìn)行操作平移剥纷,縮放操作,也就可以旋轉(zhuǎn)咯呢铆?

動(dòng)手試試:

在上面代碼的基礎(chǔ)上增加CGContextRotateCTM(context, M_PI_2 / 3.0);

完全可以晦鞋,效果如圖:

rotate.png

裁剪圓角圖片(原先圖片)

- (void)drawRect:(CGRect)rect {
    /*  裁剪圖片    */
    
    //imageSize的設(shè)置,決定圖片裁剪后的導(dǎo)出大小
    CGSize imageSize = CGSizeMake(100, 100);
    
    UIGraphicsBeginImageContextWithOptions(imageSize, NO, UIScreen.mainScreen.scale);
    
    UIBezierPath *circlePath = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0, 0, 100, 100)];
    [circlePath addClip];
    
    UIImage *clipImage = [UIImage imageNamed:@"Vokie"];
    [clipImage drawInRect:CGRectMake(0, 0, 100, 100)];
    
    /*  繪制水印    */
    NSString *waterMark = @"@vokie";
    [waterMark drawAtPoint:CGPointMake(25, 20) withAttributes:@{
        NSFontAttributeName:[UIFont systemFontOfSize:13],
        NSForegroundColorAttributeName:[UIColor whiteColor]
                                                                }];
    
    //此時(shí)導(dǎo)出的圖片的大小是受imageSize的影響棺克。
    UIImage *clipedImage = UIGraphicsGetImageFromCurrentImageContext();
    //將裁剪后的圖片圓形圖片返回出去給外部調(diào)用
    //return clipedImage;
    
    UIGraphicsEndImageContext();
    
    //將裁剪后的圖片放大并展示到context畫布上悠垛。
    [clipedImage drawInRect:CGRectMake(30, 10, 140, 140)];
}

需要注意的是,必須要先調(diào)用addClip方法娜谊,然后在draw圖片确买。先后順序不能顛倒∩唇裕可以手動(dòng)改改這些代碼湾趾,實(shí)踐出真知。運(yùn)行效果如下:

wm.png

基于上面的圓形裁剪的代碼派草,也就可以一定程度上寫出類似于上傳圖片前的矩形裁剪的代碼搀缠。基本原理是一致的近迁。

綜合理解下:

熟練掌握了iOS繪制的相關(guān)內(nèi)容(圖形文字圖像等的繪制艺普、context的平移縮放旋轉(zhuǎn),圖像尺寸縮放裁剪等),便可以解決實(shí)際開發(fā)中遇到的各種問題歧譬。因?yàn)樵陂_發(fā)中岸浑,經(jīng)常會(huì)和圖片打交道。當(dāng)然更重要的是了解其背后的底層知識(shí)瑰步。這兩篇也就是學(xué)習(xí)筆記加上入門會(huì)寫助琐。還要繼續(xù)在這個(gè)文章分類下添加更多的深入篇。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末面氓,一起剝皮案震驚了整個(gè)濱河市兵钮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌舌界,老刑警劉巖掘譬,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異呻拌,居然都是意外死亡葱轩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門藐握,熙熙樓的掌柜王于貴愁眉苦臉地迎上來靴拱,“玉大人,你說我怎么就攤上這事猾普⊥嗫唬” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵初家,是天一觀的道長(zhǎng)偎窘。 經(jīng)常有香客問我,道長(zhǎng)溜在,這世上最難降的妖魔是什么陌知? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮掖肋,結(jié)果婚禮上仆葡,老公的妹妹穿的比我還像新娘。我一直安慰自己志笼,他們只是感情好沿盅,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著籽腕,像睡著了一般嗡呼。 火紅的嫁衣襯著肌膚如雪纸俭。 梳的紋絲不亂的頭發(fā)上皇耗,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音揍很,去河邊找鬼郎楼。 笑死万伤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的呜袁。 我是一名探鬼主播敌买,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼阶界!你這毒婦竟也來了虹钮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤膘融,失蹤者是張志新(化名)和其女友劉穎芙粱,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體氧映,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡春畔,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了岛都。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片律姨。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖臼疫,靈堂內(nèi)的尸體忽然破棺而出择份,到底是詐尸還是另有隱情,我是刑警寧澤烫堤,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布缓淹,位于F島的核電站,受9級(jí)特大地震影響塔逃,放射性物質(zhì)發(fā)生泄漏讯壶。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一湾盗、第九天 我趴在偏房一處隱蔽的房頂上張望伏蚊。 院中可真熱鬧,春花似錦格粪、人聲如沸躏吊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽比伏。三九已至,卻和暖如春疆导,著一層夾襖步出監(jiān)牢的瞬間赁项,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留悠菜,地道東北人舰攒。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像悔醋,于是被迫代替她去往敵國和親摩窃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

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