老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設(shè)、域名注冊(cè)、服務(wù)器等服務(wù)

如何使用iOS實(shí)現(xiàn)圖片水印與封裝

這篇文章主要介紹了如何使用iOS實(shí)現(xiàn)圖片水印與封裝,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供安源網(wǎng)站建設(shè)、安源做網(wǎng)站、安源網(wǎng)站設(shè)計(jì)、安源網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、安源企業(yè)網(wǎng)站模板建站服務(wù),十載安源做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

首先我們了解一下什么是水印及其作用?

水印:在圖片上加的防止他人盜圖的半透明logo、文字、圖標(biāo)

水印的作用:告訴你這個(gè)圖片從哪來的,主要是一些網(wǎng)站為了版權(quán)問題、廣告而添加的。

核心代碼:

將字符串添加到圖形上下文的方法- (void)drawAtPoint:(CGPoint)point withAttributes:(nullable NSDictionary *)attrs- (void)drawInRect:(CGRect)rect withAttributes:(nullable NSDictionary *)attrs將字符串添加到圖形上下文的方法- (void)drawAtPoint:(CGPoint)point;              // mode = kCGBlendModeNormal, alpha = 1.0- (void)drawAtPoint:(CGPoint)point blendMode:(CGBlendMode)blendMode alpha:(CGFloat)alpha;- (void)drawInRect:(CGRect)rect;               // mode = kCGBlendModeNormal, alpha = 1.0- (void)drawInRect:(CGRect)rect blendMode:(CGBlendMode)blendMode alpha:(CGFloat)alpha;

基本步驟:

//1. 要手動(dòng)創(chuàng)建一個(gè)位圖上下文,創(chuàng)建位圖上下文時(shí),要指定大小,指定的大小,決定著生成圖片的尺寸是多大void UIGraphicsBeginImageContext(CGSize size);//2. 把內(nèi)容繪制到上下文當(dāng)中//2.1繪制原始圖片//2.2繪制文字//2.3繪制logo//3. 從上下文當(dāng)中生成一張圖片,把上下文當(dāng)中繪制的所有內(nèi)容合成在一起生成一張跟上下文尺度一樣的圖片UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext() ;//4.手動(dòng)創(chuàng)建的上下文一定要手動(dòng)去銷毀掉UIGraphicsEndImageContext() ;

封裝的實(shí)例代碼:

SWWaterMarkImage.h

#import NS_ASSUME_NONNULL_BEGIN@interface SWWaterMarkImage : UIImage-(UIImage *)WaterImageWithImage:(UIImage *)image ImageLogo:(UIImage *)imageLogo title:(NSString *)string ;+(UIImage *)WaterImageWithImage:(UIImage *)image ImageLogo:(UIImage *)imageLogo title:(NSString *)string ;@enDNS_ASSUME_NONNULL_END

SWWaterMarkImage.m

@implementation SWWaterMarkImage-(UIImage *)WaterImageWithImage:(UIImage *)image ImageLogo:(UIImage *)imageLogo title:(NSString *)string { //1.要手動(dòng)創(chuàng)建一個(gè)位圖上下文 UIGraphicsBeginImageContext(image.size) ; //2.繪制到內(nèi)容上下文中 //原始圖片渲染 [image drawInRect:CGRectMake(0, 0, image.size.width, image.size.height)]; //文字 NSDictionary *attributeDict = @{         NSFontAttributeName : [UIFont systemFontOfSize:20.f],         NSForegroundColorAttributeName:[UIColor whiteColor],//         NSBackgroundColorAttributeName :[UIColor redColor]         } ; CGRect rectSize = [string boundingRectWithSize:CGSizeMake(MAXFLOAT, 30) options:NSStringDrawingUsesDeviceMetrics attributes:attributeDict context:nil] ; CGFloat x = image.size.width - rectSize.size.width - 10 ; CGFloat y = image.size.height - 30 ; [string drawAtPoint:CGPointMake(x, y) withAttributes:attributeDict] ; //logo圖片 CGFloat waterW = 30; CGFloat waterH = 30; CGFloat waterX = x - waterW - 10 ; CGFloat waterY = y - 3 ; [imageLogo drawInRect:CGRectMake(waterX, waterY, waterW, waterH)] ; //3.從當(dāng)前的上下文當(dāng)中生成一張新的圖片 UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext() ; //4.手動(dòng)創(chuàng)建的上下文一定要手動(dòng)去銷毀掉 UIGraphicsEndImageContext() ; return newImage ;}+(UIImage *)WaterImageWithImage:(UIImage *)image ImageLogo:(UIImage *)imageLogo title:(NSString *)string { return [[self alloc]WaterImageWithImage:image ImageLogo:imageLogo title:string] ;}@end

ViewController.m

#import "ViewController.h"#import "SWWaterMarkImage.h"@interface ViewController ()@property(nonatomic,strong)UIImageView *imageView ;@end@implementation ViewController- (void)viewDidLoad { [super viewDidLoad]; //生成一張加水印圖片步驟: /*  可以在任何方法中生成圖片,不一定在drawRect:方法中生成  1.要手動(dòng)創(chuàng)建一個(gè)位圖上下文,創(chuàng)建位圖上下文時(shí),要指定大小,指定的大小,決定著生成圖片的尺寸是多大  2.把內(nèi)容繪制到上下文當(dāng)中  3.從上下文當(dāng)中生成一張圖片,把上下文當(dāng)中繪制的所有內(nèi)容合成在一起生成一張跟上下文尺度一樣的圖片  4.手動(dòng)創(chuàng)建的上下文一定要手動(dòng)去銷毀掉  */}-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{ UIImage *newImage = [SWWaterMarkImage WaterImageWithImage:[UIImage imageNamed:@"18d8bc3eb13533fa65021ddba5d3fd1f40345b8b"] ImageLogo:[UIImage imageNamed:@"logo"] title:@"蕪湖亞原子網(wǎng)絡(luò)科技有限公司"] ; //5.將生成的image顯示到imageView上去 self.imageView = [[UIImageView alloc]init] ; self.imageView.frame = CGRectMake(0, 100, 375, 250) ; self.imageView.image = newImage ; [self.view addSubview:self.imageView] ;}@end

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何使用iOS實(shí)現(xiàn)圖片水印與封裝”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!


網(wǎng)站欄目:如何使用iOS實(shí)現(xiàn)圖片水印與封裝
當(dāng)前網(wǎng)址:http://www.xueling.net.cn/article/jsgdgj.html

其他資訊

在線咨詢
服務(wù)熱線
服務(wù)熱線:028-86922220
TOP
主站蜘蛛池模板: 色婷婷一区| 日韩aaa视频| 欧美日本另类 | 91最新入口| 日本丰满少妇BBB | 亚洲女教师丝祙在线播放 | 成年人免费看 | 91精品国产综合久久久久久丝袜 | 未满小14洗澡无码视频网站 | 色欲av蜜臀av久久浪潮av | 99国内精品久久久久 | 国产国产成年年人免费看片 | 一级黄色片播放 | 99久久精品免费看蜜桃的推荐词 | 亚洲欧美洲成人一区二区 | 真人作爱视频免费 | 91九色视频网站 | 男人添女人下部高潮视频 | 日本欧洲乱码伦视频免费 | 四虎国产精品成人 | 青青操综合网 | 久久欧美高清二区三区 | 影音先锋资源爱色 | 精品久久免费观看 | 超碰在线资源 | 久久久久久久亚洲国产精品87 | porn一区 | 国产伦精品一区二区三区免费观看 | 国产亚洲一区二区三区 | 久久久亚洲欧洲日产国码αv | 中字幕视频在线永久在线 | 一级一级国产片 | 日韩黄色网页 | 黄色免费在线播放 | 天天干天天操天天 | 精品一区二区中文字幕 | 精品国产欧美另类一区 | 国产福利一区二区三区视频 | 成人的性行为免费 | 日本aaaa级毛片在线看 | 国产成人美女AV |