iOS获取手指点击背景图的坐标的颜色(亲测,不需要关心UIImageView的frame是否跟图片大小一样)

公司最近要做一个拾色器,就是自己手动选择一张图片,获取手指点击的哪一个点的颜色,然后跳转其他页面,做颜色调试.

思考的问题:

1.刚接到这需求的时候,在网上搜了一下方法,获取点击点的颜色方法很多,但是都有一个弊端,就是一定要求,UIImageView的frame一定要跟图片一样,才能准确获取点得色彩.

2.因为还需要对图片做缩放的功能,考虑到可以把图片放到scrollView和在图片上添加手势两种方法(鉴于没有经验,只好都尝试一遍,发现scrollView是完美的)

3.获取手指点击的坐标,一开始通过添加手势来缩放,可以直接调用系统TouchBegin方法获取,但是将imageView放在scrollView中,次方法获取不到坐标点,只能对imageView添加一个单点击手势.

实现思路:

1.获取需要展示的图片,并且拿到款和高,添加一个bgImageView,frame设置为图片大小,直接添加到当前控制器View上.

2.添加一个scrollView到控制器View上,frame设置为view.bounds.

3.获取需要展示的图片,并且拿到图片的宽和高.然后除以当前屏幕宽和高,获取一个比例scale.添加一个imageView到scrollView上,frame是经过比例缩放的.

4.添加一个单击手势给imageView,实现对应的方法通过手势方法获取点:CGPoint point = [sender locationInView:_imageView].

5.在获取色调的方法中,传进去的image是bgImageView的image属性,坐标点是乘以刚刚第二步计算的出来的scale,这样,点击屏幕的点就可以准确获取到图片对应点得颜色.

贴出获取色彩的代码:

- (UIColor*)getPixelColorAtLocation:(CGPoint)point  

{  UIColor* color = [UIColor whiteColor];  

[self.colorArr removeAllObjects];  

if (point.x < self.imageView.frame.size.width && point.x > 0 && point.y < self.imageView.frame.size.height && point.y > 0) {  UIImageView *colorImageView=self.backgroundImageV;  CGImageRef inImage = colorImageView.image.CGImage;  


// Create off screen bitmap context to draw the image into. Format ARGB is 4 bytes for each pixel: Alpa, Red, Green, Blue  


CGContextRef cgctx = [self createARGBBitmapContextFromImage:inImage];  


if (cgctx == NULL)  

        {  

return nil;  

        }  


size_t w = CGImageGetWidth(inImage);  


size_t h = CGImageGetHeight(inImage);  


CGRect rect = {{0,0},{w,h}};  


// Draw the image to the bitmap context. Once we draw, the memory  


// allocated for the context for rendering will then contain the  


// raw image data in the specified color space.  


        CGContextDrawImage(cgctx, rect, inImage);  


// Now we can get a pointer to the image data associated with the bitmap  


// context.  


unsignedchar* data = CGBitmapContextGetData (cgctx);  


if (data != NULL)  


{//offset locates the pixel in the data from x,y.  


//4 for 4 bytes of data per pixel, w is width of one row of data.  


@try  

            {  

int offset = 4*((w*round(point.y * self.scale))+round(point.x * self.scale));  


//NSLog(@"offset: %d", offset);  


int alpha =  data[offset];  


int red = data[offset+1];  


int green = data[offset+2];  


int blue = data[offset+3];  //            NSLog(@"offset: %i colors: RGB A %i %i %i  %i",offset,red,green,blue,alpha);  

NSLog(@"%d%d%d",red,green,blue);  

[self.colorArr addObject:@(alpha / 255.0f)];  

[self.colorArr addObject:@(red)];  

[self.colorArr addObject:@(green)];  

[self.colorArr addObject:@(blue)];  

color = [UIColor colorWithRed:(red/255.0f) green:(green/255.0f) blue:(blue/255.0f) alpha:(alpha/255.0f)];             }  

@catch (NSException * e)  

            {  

NSLog(@"%@",[e reason]);  

            }  

@finally  

            { 

            } 

        } 

// When finished, release the context 

        CGContextRelease(cgctx); 

// Free image data memory for the context 

if (data)  

        {  

            free(data);  

        } 

    }  

self.pickView.backgroundColor = color;  

return color; 

- (CGContextRef) createARGBBitmapContextFromImage:(CGImageRef) inImage {  

CGContextRef    context =NULL;

   CGColorSpaceRef colorSpace; 

voidvoid *          bitmapData; 

int             bitmapByteCount; 

int             bitmapBytesPerRow; 

// Get image width, height. We'll use the entire image. 

size_t pixelsWide = CGImageGetWidth(inImage); 

size_t pixelsHigh = CGImageGetHeight(inImage); 

// Declare the number of bytes per row. Each pixel in the bitmap in this 

// example is represented by 4 bytes; 8 bits each of red, green, blue, and 

// alpha. 

bitmapBytesPerRow   = (int)(pixelsWide * 4); 

bitmapByteCount     =(int)(bitmapBytesPerRow * pixelsHigh); 

// Use the generic RGB color space. 

    colorSpace = CGColorSpaceCreateDeviceRGB();  

if (colorSpace == NULL)  

    { 

fprintf(stderr,"Error allocating color space\n"); 

return NULL; 

    }  

// Allocate memory for image data. This is the destination in memory 

// where any drawing to the bitmap context will be rendered.  

    bitmapData = malloc( bitmapByteCount ); 

if (bitmapData == NULL) 

    { 

fprintf (stderr,"Memory not allocated!"); 

        CGColorSpaceRelease( colorSpace ); 

return NULL; 

    }  

// Create the bitmap context. We want pre-multiplied ARGB, 8-bits 

// per component. Regardless of what the source image format is 

// (CMYK, Grayscale, and so on) it will be converted over to the format 

// specified here by CGBitmapContextCreate. 

    context = CGBitmapContextCreate (bitmapData,  

                                     pixelsWide, 

                                     pixelsHigh, 

8,      // bits per component  

                                     bitmapBytesPerRow, 

                                    colorSpace, 

                                     kCGImageAlphaPremultipliedFirst); 

if (context == NULL) 

    { 

        free (bitmapData); 

fprintf (stderr,"Context not created!"); 

    }  

// Make sure and release colorspace before returning 

    CGColorSpaceRelease( colorSpace );  

return context; 

}  

到此,此功能需求完美实现,需要源码的小伙伴,可以留言交流~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,525评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,203评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,862评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,728评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,743评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,590评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,330评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,244评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,693评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,885评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,001评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,723评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,343评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,919评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,042评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,191评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,955评论 2 355

推荐阅读更多精彩内容