iOS圖片處理相關(guān)

最近公司項(xiàng)目要做圖片處理這里總結(jié)一下:

1.普通上下文

CGContextRef ref = UIGraphicsGetCurrentContext();
CGContextSaveGState(ref);
XXXXX
XXXXX
CGContextRestoreGState(ref);

2.遮罩處理

利用圖層

CAShapeLayer *maskLayer = [CAShapeLayer layer];
maskLayer.frame = self.bounds;
maskLayer.fillMode = kCAFillRuleEvenOdd;
// UIBezierPath *maskLayerPath = [UIBezierPath bezierPath];
// [maskLayerPath appendPath:[UIBezierPath bezierPathWithOvalInRect:CGRectMake(5, 5, 100, 100)]];
// maskLayer.path = maskLayerPath.CGPath;
maskLayer.contents = (__bridge id _Nullable)(maskImage.CGImage);
[self.layer setMask:maskLayer];

3.剪切遮罩處理(針對(duì)圖片)

1.CGContextClipToMask(ref, self.bounds, imgRef);

按圖片剪裁context,alpha=0干掉,alpha=1留下;
參數(shù) CGContextRef Rect CGImageRef

2.CGImageCreateWithMask([image CGImage], mask);

兩張圖片,mask處理,mask圖片alpha=1,純白表示透明, 純黑表示要留下, 其他顏色,相應(yīng)混合處理

CGImageCreateWithMaskingColors([image CGImage], CGFloat _UnNull maskColor);

一張圖片,按colorspace的要求進(jìn)行處理

- (UIImage*)maskImage:(UIImage *)image withMask:(UIImage *)maskImage {
    
    //    UIImage *blackImg = [self imageBlackToTransparent:maskImage];
    //    CGImageRef maskRef = blackImg.CGImage;
    
    CGImageRef maskRef = maskImage.CGImage;
    
    maskRef = [PuzzleView maskableImageRefConvertFrom:maskRef];
    
    //    const CGFloat maskcolor[6] = {0,0,0,0,0,0};
    //    CGImageRef maskRef = CGImageCreateWithMaskingColors(maskImage.CGImage, maskcolor);
    
    CGImageRef mask = CGImageMaskCreate(CGImageGetWidth(maskRef),
                                        CGImageGetHeight(maskRef),
                                        CGImageGetBitsPerComponent(maskRef),
                                        CGImageGetBitsPerPixel(maskRef),
                                        CGImageGetBytesPerRow(maskRef),
                                        CGImageGetDataProvider(maskRef), NULL, false);
    
    CGImageRef masked = CGImageCreateWithMask([image CGImage], mask);
    return [UIImage imageWithCGImage:masked];

    //    UIImage *blackImg = [self imageBlackToTransparent:maskImage];
    //    CGImageRef maskRef = blackImg.CGImage;
    //    CGImageRef mask = CGImageMaskCreate(CGImageGetWidth(maskRef),
    
//        CGImageGetHeight(maskRef),
//
//        CGImageGetBitsPerComponent(maskRef),
//
//        CGImageGetBitsPerPixel(maskRef),
//
//        CGImageGetBytesPerRow(maskRef),
//        CGImageGetDataProvider(maskRef), NULL, false);
    //    CGImageRef sourceImage = [image CGImage];
    //    CGImageRef imageWithAlpha = sourceImage;
    //    [self imageDump:maskImage];
    
    //    if (CGImageGetAlphaInfo(sourceImage) == kCGImageAlphaNone) {
    //        imageWithAlpha = [self CopyImageAndAddAlphaChannel:sourceImage];
    //    }
    //    CGImageRef masked = CGImageCreateWithMask(imageWithAlpha, mask);
    //    CGImageRelease(mask);
    //    if (sourceImage != imageWithAlpha) {
    //        CGImageRelease(imageWithAlpha);
    //    }
    //    UIImage* retImage = [UIImage imageWithCGImage:masked];
    //    CGImageRelease(masked);
    //    return retImage;
}

4.關(guān)于截屏失真

- (IBAction)saveBtnTap:(UIButton *)sender {
// 這個(gè)方法將scale 變?yōu)槠聊?scale,默認(rèn)1.0.  改為屏幕scale后變?yōu)槠聊环直媛?    UIGraphicsBeginImageContextWithOptions(self.mainView.bounds.size, NO, [UIScreen mainScreen].scale);
    [self.mainView.layer renderInContext:UIGraphicsGetCurrentContext()];
    UIImage *image=UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();
    UIImageWriteToSavedPhotosAlbum(image,nil, nil, nil);
    UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"" message:@"保存成功" delegate:self cancelButtonTitle:@"取消" otherButtonTitles:nil, nil];
    [alertView show];
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容