久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

iOS整個APP實現(xiàn)灰色主題的示例代碼

瀏覽:4日期:2022-09-16 18:46:40
灰色主題背景

在一些哀悼日,清明節(jié)的時候app會實現(xiàn)一些灰色主題功能,部分app需求是tab首頁實現(xiàn)灰色模式就可以,但一些需求是直接整個app都變?yōu)榛疑!?/p> 普通UI界面 web頁面 xib界面 attributeText加載的htmlString頁面 attachment掛件頁面實現(xiàn)方式

基本的實現(xiàn)方式1,普通頁面用hook顏色方式2.web頁面用注入灰色js實現(xiàn)方式

圖片變灰

重新繪制圖片變?yōu)榛疑a實現(xiàn)

//image類別- (UIImage *)getGrayImage { const int RED =1; const int GREEN =2; const int BLUE =3; UIImage *image = self; // Create image rectangle with current image width/height CGRect imageRect = CGRectMake(0,0, image.size.width* image.scale, image.size.height* image.scale); int width = imageRect.size.width; int height = imageRect.size.height; // the pixels will be painted to this array uint32_t *pixels = (uint32_t*) malloc(width * height *sizeof(uint32_t)); // clear the pixels so any transparency is preserved memset(pixels,0, width * height *sizeof(uint32_t)); CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); // create a context with RGBA pixels CGContextRef context = CGBitmapContextCreate(pixels, width, height,8, width *sizeof(uint32_t), colorSpace, kCGBitmapByteOrder32Little | kCGImageAlphaPremultipliedLast); // paint the bitmap to our context which will fill in the pixels array CGContextDrawImage(context,CGRectMake(0,0, width, height), [image CGImage]); for(int y = 0; y < height; y++) { for(int x = 0; x < width; x++) { uint8_t *rgbaPixel = (uint8_t*) &pixels[y * width + x]; // convert to grayscale using recommended method: http://en.wikipedia.org/wiki/Grayscale#Converting_color_to_grayscale uint32_t gray = 0.3 * rgbaPixel[RED] +0.59 * rgbaPixel[GREEN] +0.11 * rgbaPixel[BLUE]; // set the pixels to gray rgbaPixel[RED] = gray; rgbaPixel[GREEN] = gray; rgbaPixel[BLUE] = gray; } } // create a new CGImageRef from our context with the modified pixels CGImageRef imageRef = CGBitmapContextCreateImage(context); // we’re done with the context, color space, and pixels CGContextRelease(context); CGColorSpaceRelease(colorSpace); free(pixels); // make a new UIImage to return UIImage *resultUIImage = [UIImage imageWithCGImage:imageRef scale:image.scale orientation:UIImageOrientationUp]; // we’re done with image now too CGImageRelease(imageRef); return resultUIImage; }文本變灰

文本textColor變?yōu)榛疑?rgb的處理有很多這里簡單提供一個

[self swizzleMethod:self orgSel:@selector(initWithRed:green:blue:alpha:) swizzSel:@selector(hdd_initWithRed:green:blue:alpha:)];+ (UIColor *)hdd_colorWithRed:(CGFloat)red green:(CGFloat)green blue:(CGFloat)blue alpha:(CGFloat)a{ CGFloat gray = red*0.299 + green*0.587 + blue*0.114; if ([CSDarkSiteManager isLocalCacheDarkSiteStatus]) { return [self hdd_colorWithRed:gray green:gray blue:gray alpha:a]; } else { return [self hdd_colorWithRed:red green:green blue:blue alpha:a]; }}

文本變灰色還牽扯到系統(tǒng)顏色的灰色處理,例如[UIcolor whiteColor],系統(tǒng)alertView彈框中的藍(lán)色按鈕顏色處理,都需要有專門的處理方法

xib圖片變灰

由于xib讀取圖片不是直接通過[UIimageView imageName:@''] 加載方式 沒辦法直接通過hook setImage直接設(shè)置xib圖片變?yōu)榛疑?/p>

方法:重寫UIimageView的awakeFromNib,再去執(zhí)行hook setImage的方法進(jìn)行加載

webView的變灰

hook webView的初始化方法,注入js灰色

+ (void)swizzHook { static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ Method originalMethod = class_getInstanceMethod([self class], @selector(initWithFrame:configuration:)); Method swizzledMethod = class_getInstanceMethod([self class], @selector(lg_initWithFrame:configuration:)); method_exchangeImplementations(originalMethod, swizzledMethod); });}- (instancetype)lg_initWithFrame:(CGRect)frame configuration:(WKWebViewConfiguration *)configuration { Class class = NSClassFromString(@'AIRWKWebView'); if ([CSDarkSiteManager isLocalCacheDarkSiteStatus] && ![self isKindOfClass:class]) { NSString *jScript = @'var filter = ’-webkit-filter:grayscale(100%);-moz-filter:grayscale(100%); -ms-filter:grayscale(100%); -o-filter:grayscale(100%) filter:grayscale(100%);’;document.getElementsByTagName(’html’)[0].style.filter = ’grayscale(100%)’;'; // 注入 WKUserScript *wkUScript = [[WKUserScript alloc] initWithSource:jScript injectionTime:WKUserScriptInjectionTimeAtDocumentEnd forMainFrameOnly:YES]; [configuration.userContentController addUserScript:wkUScript]; WKWebView *webView = [self lg_initWithFrame:frame configuration:configuration]; return webView; } else { WKWebView *webView = [self lg_initWithFrame:frame configuration:configuration]; return webView; } }

attributeText加載htmlString變灰

attribute情況下加載html不是直接通過設(shè)置color來改變顏色的,需要通過遍歷對應(yīng)的屬性進(jìn)行重新顏色進(jìn)行賦值

存在的問題

這樣全局修改,可能會把鍵盤的顏色也改變了需要特殊處理

系統(tǒng)顏色中,alertView中的藍(lán)色,不在定義的系統(tǒng)顏色范圍之內(nèi)需要重新加載

hook系統(tǒng)顏色的處理

完整性

需要完整的私發(fā)信息

iOS整個APP實現(xiàn)灰色主題的示例代碼

到此這篇關(guān)于iOS整個APP實現(xiàn)灰色主題的示例代碼的文章就介紹到這了,更多相關(guān)iOS 灰色主題內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: IOS
相關(guān)文章:
主站蜘蛛池模板: 在线观看91| 99精品免费视频 | 久久九九国产精品 | 夜夜操天天操 | www.9191 | 天天干天操 | 亚洲精品综合 | 欧美视频在线观看一区 | 精品www| 欧产日产国产精品一二 | 久久久精品国产 | 91黄在线观看 | 亚洲精品一区二区三区蜜桃下载 | 久久国产精品免费一区二区三区 | 亚洲精品一区在线观看 | 日本在线网 | 最新国产在线视频 | 在线高清av | 女人久久久久 | 羞羞视频在线网站观看 | 91一区二区三区久久国产乱 | 日本在线黄色 | 在线中文字幕第一页 | www.com国产精品| 精品日韩视频 | 日韩视频在线观看不卡 | 国产精品永久久久久久久久久 | 一区二区三区四区视频 | 国产视频大全 | 在线免费观看日韩视频 | 国产欧美精品 | 国产日产欧美a级毛片 | 欧美不卡一区二区三区 | av免费在线观看网址 | av一区二区三区 | 国产一区二区三区免费 | 国产精品一码二码三码在线 | 亚洲性视频网站 | 黄色91在线 | 日韩精品99久久久久中文字幕 | 91九色在线观看 |