今天突然有需求,需要顯示手機(jī)附近的HUD路況,由于要反射到HUD上,所以顏色必須以藍(lán),黑,白為主,顯示效果才最好。無(wú)奈高德地圖的路況地圖不支持背景顏色的調(diào)整,只能想辦法把mapView截取成imageView并且改變imageView的RGB來(lái)實(shí)現(xiàn),試試吧。。。
首先尋找到截圖:
UIImage *screenshotImage = [self.mapView takeSnapshotInRect:self.view.bounds];
為數(shù)據(jù)源;
其次找到方法:
<pre>void ProviderReleaseData (void *info, const void data, size_t size)
{
free((void)data);
}
-
(UIImage) imageBlackToTransparent:(UIImage) image
{
// 分配內(nèi)存
const int imageWidth = image.size.width;
const int imageHeight = image.size.height;size_t bytesPerRow = imageWidth * 4;
uint32_t* rgbImageBuf = (uint32_t*)malloc(bytesPerRow * imageHeight);
// 創(chuàng)建context
CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
CGContextRef context = CGBitmapContextCreate(rgbImageBuf, imageWidth, imageHeight, 8, bytesPerRow, colorSpace,
kCGBitmapByteOrder32Little | kCGImageAlphaNoneSkipLast);
CGContextDrawImage(context, CGRectMake(0, 0, imageWidth, imageHeight), image.CGImage);// 遍歷像素
int pixelNum = imageWidth * imageHeight;
uint32_t* pCurPtr = rgbImageBuf;
for (int i = 0; i < pixelNum; i++, pCurPtr++)
{
if ((pCurPtr & 0x00ff0000)>>16 == 237)
{
uint8_t ptr = (uint8_t*)pCurPtr;
ptr[3] = 0x00; //0~255
ptr[2] = 0x00;
ptr[1] = 0x00;
//ptr[0] = 0x00;
}
}// 將內(nèi)存轉(zhuǎn)成image
CGDataProviderRef dataProvider = CGDataProviderCreateWithData(NULL, rgbImageBuf, bytesPerRow * imageHeight, ProviderReleaseData);
CGImageRef imageRef = CGImageCreate(imageWidth, imageHeight, 8, 32, bytesPerRow, colorSpace,
kCGImageAlphaLast | kCGBitmapByteOrder32Little, dataProvider,
NULL, true, kCGRenderingIntentDefault);
CGDataProviderRelease(dataProvider);UIImage* resultUIImage = [UIImage imageWithCGImage:imageRef];
// 釋放
CGImageRelease(imageRef);
CGContextRelease(context);
CGColorSpaceRelease(colorSpace);return resultUIImage;
}</pre>
這里面(*pCurPtr & 0x00ff0000)>>16==237是像素點(diǎn)的R值==237時(shí),并把這個(gè)像素點(diǎn)設(shè)置為RGB000的黑色。
但是轉(zhuǎn)化完畢的圖片會(huì)毛毛躁躁,很可能會(huì)不規(guī)則,而且如何得到我們想轉(zhuǎn)換的顏色的R值呢?
我是這樣做的,把圖片截圖后,寫(xiě)了一個(gè)demo,具體是這樣:
<pre>-(void)viewDidLoad {
[super viewDidLoad];
_dic = [[NSMutableDictionary alloc]init];
for (int i = 0; i++; i<=255) {
[_dic setObject:[NSNumber numberWithInt:0] forKey:[NSString stringWithFormat:@"%d",i]];
}
[self startCopyImage];
int tempX = 0;
int j = 0;
while (j<=255) {
j++;
NSLog(@"%d",[[_dic objectForKey:[NSString stringWithFormat:@"%d",j]] intValue]);
if ([[_dic objectForKey:[NSString stringWithFormat:@"%d",j]] intValue]>=tempX) {
tempX = [[_dic objectForKey:[NSString stringWithFormat:@"%d",j]] intValue];
}
}
NSLog(@"X---%d",tempX);
NSLog(@"Y---%@",_dic);
}</pre>
這樣X(jué)---打印出的是這個(gè)圖片中像素點(diǎn)R值出現(xiàn)最多的次數(shù),搜索打印結(jié)果后就可以在Y---中看到哪個(gè)像素點(diǎn)最常見(jiàn),此時(shí)提供的截圖最好為大部分都是你想去掉的顏色,這樣就得出這個(gè)顏色的R值。稍微改進(jìn)排序后你可以對(duì)圖片的前幾名多顏色的R值都德刀,并且利用上面的方法改變顏色。
還有找到一個(gè)判斷像素點(diǎn)rgb來(lái)判斷這個(gè)界面上出現(xiàn)最多的顏色 代碼如下
-(UIColor*)mostColor:(UIImage*)image{
#if __IPHONE_OS_VERSION_MAX_ALLOWED > __IPHONE_6_1
int bitmapInfo = kCGBitmapByteOrderDefault | kCGImageAlphaPremultipliedLast;
#else
int bitmapInfo = kCGImageAlphaPremultipliedLast;
#endif
//第一步 先把圖片縮小 加快計(jì)算速度. 但越小結(jié)果誤差可能越大
CGSize thumbSize=CGSizeMake(300, 300);
CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
CGContextRef context = CGBitmapContextCreate(NULL,
thumbSize.width,
thumbSize.height,
8,//bits per component
thumbSize.width*4,
colorSpace,
bitmapInfo);
CGRect drawRect = CGRectMake(0, 0, thumbSize.width, thumbSize.height);
CGContextDrawImage(context, drawRect, image.CGImage);
CGColorSpaceRelease(colorSpace);
//第二步 取每個(gè)點(diǎn)的像素值
unsigned char* data = CGBitmapContextGetData (context);
if (data == NULL) return nil;
NSCountedSet *cls=[NSCountedSet setWithCapacity:thumbSize.width*thumbSize.height];
for (int x=0; x<thumbSize.width; x++) {
for (int y=0; y<thumbSize.height; y++) {
int offset = 4*(x*y);
int red = data[offset];
int green = data[offset+1];
int blue = data[offset+2];
int alpha = data[offset+3];
NSArray *clr=@[@(red),@(green),@(blue),@(alpha)];
[cls addObject:clr];
}
}
CGContextRelease(context);
//第三步 找到出現(xiàn)次數(shù)最多的那個(gè)顏色
NSEnumerator *enumerator = [cls objectEnumerator];
NSArray *curColor = nil;
NSArray *MaxColor=nil;
NSUInteger MaxCount=0;
while ( (curColor = [enumerator nextObject]) != nil )
{
NSUInteger tmpCount = [cls countForObject:curColor];
if ( tmpCount < MaxCount ) continue;
MaxCount=tmpCount;
MaxColor=curColor;
}
return [UIColor colorWithRed:([MaxColor[0] intValue]/255.0f) green:([MaxColor[1] intValue]/255.0f) blue:([MaxColor[2] intValue]/255.0f) alpha:([MaxColor[3] intValue]/255.0f)];}
此時(shí)我們只需要截圖需要的主色調(diào)成uiimage,便能方便的獲取這種顏色的色調(diào)
并且在上面改變顏色的方法中進(jìn)行判斷
(*pCurPtr & 0xFFFFFF00) == 0XF8EEE200
或者
((pCurPtr & 0xFF000000)>>24 == 248 && (pCurPtr & 0x00FF0000)>>16 == 238 (*pCurPtr & 0x0000FF00)>>8 == 226)
就可以過(guò)濾出這種顏色的像素點(diǎn),
0xFFFFFF00代表著RGB為255,255,255,0
0XF8EEE200代表著RGB為248,238,226,0
16進(jìn)制的顏色,0X后每2位代表著16進(jìn)制的RGB值;
如此之后我的圖片變成了


在此張圖片的效果并不好是因?yàn)閳D片顏色相近并且RGB顏色都有細(xì)小的差別 不能整個(gè)進(jìn)行扣圖處理 但是相信對(duì)一部分圖片還是有處理能力的,歡迎補(bǔ)充和拍磚