colorui开发文档_colorui开发小程序
2025-03-22 12:56 - 立有生活网
ios开发UIColor,CGColor,CIColor三者的区别和联系
);个函数是获得CGColorRef的中包含的颜色组成部分的个数,第二个函数就是获取实际的颜色组成部分的数组,下面看一个小例子:最近看了看CoreGraphics的东西,看到关于CGColor的东西,于是就想着顺便看看UIColor,CIColor,弄清楚它们之间的区别和联系。下面我们分别看看它们三个的概念:
colorui开发文档_colorui开发小程序
colorui开发文档_colorui开发小程序
UIColor是UIKit中存储颜色信息的一个重要的类,一个UIColor对象包含了颜色和透明度的值,它的颜色空间已经针对IOS进行了优化。UIColor包含了一些类方法用于创建一些最常见的颜色,如白色,黑色,红色,透明色等,这些颜色的色彩空间也不尽相同(白色和黑色是kCGColorSpaceDevGray,红色的色彩空间是kCGColorSpaceDevRGB)。
此外UIColor还有两个重要的属性:一个是CGColor,一个是CIColor(5.0之后添加)。这两个属性就可以把UIColor,CGColor,CIColor三个对象联系起来了,后面会详细介绍这三者之间的转换。
二、CGC// judge two CGColor is equalolor
1、如何创建一个CGColor,最常用的函数是CGColorCreate,该函数有两个参数:
1) colorspace,指定CGColor对应的颜色空间,Quartz就会retain该对象,因此调用完之后你就可以安全的释放该对象。
该函数该返回一个新创建的CGColorRef,当我们不再使用该对象的时候使用CGColorRelease函数释放该对象。
2、获取CGColor的数据
在我们创建的时候传入两个重要的参数进去,当我们获取到了CGColorRef以后当然就可以拿到对应的ColorSpace以及Components。
1) 获取ColorSpace
通过CGColorGetColorSpace函数我们可以获取到当前CGColorRef对应的ColorSpace,该函数只接受一个参数就是你要获取ColorSpace的CGColorRef。下面请看一个简单的例子:
CGColorRef cgColor = [UIColor redColor].CGColor;
CGColorSpaceRef colorSpace = CGColorGetColorSpace(cgColor);
要获取到CGColorRef对应的颜色值,我们需要用到CGColorGetNumberOfComponents和CGColorGetComponents两个函数。我们先来看看两个函数的函数原型:
size_t CGColorGetNumberOfComponents (
);
const CGFloat CGColorGetComponents (
NSUInteger num = CGColorGetNumberOfComponents(cgColor);
const CGFloat colorComponents = CGColorGetComponents(cgColor);
for (int i = 0; i < num; ++i) {
NSLog(@"color components %d: %f", i, colorComponents[i]);
}三、CIColor
CIColor主要是用于和Core Image框架中其他类,比如CIFilter,CIContext以及CIImage。今天我们主要关心的颜色值部分,CIColor中颜色值的范围是0.0-1.0之间,0.0代表该颜色分量为最小值,1.0代表改颜色分量为值。其中alpha值的范围也是0.0到1.0之间,0.0代表全透明,1.0代表完全不透明,同时CIColor的颜色分量通常都是没有乘以alpha值。
我们可以使用initWithCGColor:函数,通过CGColor创建一个CIColor。其中传入的CGColorRef对象可以使任何任何颜色空间,但是Core Image框架会在传入filter kernel之前把所有的颜色空间转换到core image工作颜色空间。core image工作颜色空间使用三个颜色分量加上一个alpha分量组成(其实就是kCGColorSpaceDevRGB),后面的例子中我们验证这一点。
四、UIColor,CGColor,CIColor的区别和联系
1、UIColor的两个属性CGColor,CIColor
UIColor的CGColor总是有效的,不管它是通过CGColor,CIColor,还是其他方法创建的,CGColor属性都总是有效的;但是CIColor属性就不总是有效的,只有当UIColor是通过CIColor创建的时候,他才是有效的,否则访问该属性将会抛出异常,下面照旧来一个小例子:
// test init uicolor with CGColor
UIColor color = [UIColor colorWithCGColor:[UIColor whiteColor].CGColor];
// CGColor property is always valid
NSLog(@"CGColor from UIColor %@", color.CGColor);
// don't use CIColor property
// This property throws an exception if the color object was not initialized with a Core Image color.
NSLog(@"CIColor from UIColor %@", color.CIColor); // crush2、UIColor使用CGColor初始化
当UIColor使用CGColor初始化的时候,所有CGColorRef包含的信息,都会被原封不动的保留,其中就包括Color space,而且通过下面的小例子我们还可以看到如果使用CGColor初始化UIColor的时候,UIColor其实是直接保留了一份这个CGColorRef对象。例子如下:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
// color with CGColor, uicolor will just retain it
UIColor color = [UIColor colorWithCGColor:colorCMYK];
NSLog(@"CGColor from UIColor: %@", color.CGColor);3、UIColor使用CIColor初始化
1) 使用kCGColorSpaceDevGray初始化CIColor
首先看代码:
// test kCGColorSpaceDevGray
NSLog(@"CGColor white color:%@", [UIColor whiteColor].CGColor);
CIColor ciColor = [CIColor colorWithCGColor:[UIColor whiteColor].CGColor];
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@"NSLog(@"color space: %@", colorSpace);2) 获取Color Components, color);
// Core Image converts all color spaces to the Core Image working color
// space before it passes the color space to the filter kernel.
// kCGColorSpaceDevGray ---> kCGColorSpaceDevRGB
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);通过运行程序,我们看出来,如果使用一个kCGColorSpaceDevGray的颜色空间的CGColor来初始化CIColor的时候,我们可以看到CIColor的色彩空间一直是kCGColorSpaceDevGray,通过访问UIColor的CIColor属性,我们可以看到其颜色空间仍然是kCGColorSpaceDevGray,但是当访问UIColor的CGColor属性的时候,通过打印可以发现其色彩空间已经转变成了kCGColorSpaceDevRGB空间了,而颜色值也正确的从原来的颜色空间转换到了新的颜色空间。
同样的我们看代码:
//test kCGColorSpaceDevRGB
CIColor ciColor = [CIColor colorWithCGColor:[UIColor redColor].CGColor];
UIColor color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);整个过程中CIColor,以及通过UIColor的CGColor和CIColor属性访问到的值,打印出来我们可以发现它们都是kCGColorSpaceDevRGB空间的。
4、使用kCGColorSpaceDevCMYK初始化CIColor
下面继续看一段代码:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
NSLog(@"Components number: %zu", CGColorSpaceGetNumberOfComponents(cmykSpace));
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
ciColor = [CIColor colorWithCGColor:colorCMYK];
NSLog(@"cicolor: %@", ciColor); // in fact,the color value of CIColor has converted to RGB Colorspace
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"UIColor with CIColor: %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
// when UIColor init with CIColor, UIColor's CGColor will convert other colorspace to kCGColorSpaceDevRGB
NSLog(@"cgcolor from UIColor: %@", color.CGColor);整个过程中,我们通过运行同样可以发现,当我们用一个CMYK颜色空间的CGColor来初始化CIColor的时候,CIColor的颜色空间依然是CMYK,但是颜色值已经转换成RGB的颜色值。当使用该CIColor创建一个UIColor的时候,我们再通过CIColor和CGColor属性打印信息的时候,我们会发现CIColor的色彩空间依然是CMYK,但是CGColor打印所得到的信息说明它已经被转换成RGB空间了。
五、UIColor延伸,如何判断两个颜色是否相等
前面提到一点,不管UIColor使用CIColor,CGColor还是其他方式初始化的,其CGColor属性都是可用的。CoreGraphics中提供一个方法可以判断两个CGColor是否相等,因此我们可以通过判断两个UIColor是否相等,下面是看一个简单的例子:
if (CGColorEqualToColor([UIColor whiteColor].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}if (CGColorEqualToColor([UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}例子中部分是判断两个白色的UIColor是否相等,虽然都是白色,但是颜色空间是不一样的,通过运行我们可以发现,打印出“The two CGColor is not equal!”。例子的第二部分简单的创建了两个RGB空间的UIColor,运行程序可以看出,这两种颜色是相同的。
转载
基于uni-app开发的实时公交车小程序
首NSLog(@"cicolor: %@", ciColor);先使用hbuild开发工具新建一个uni-app项目,早期版本的hbuild有uview-ui可以直接导入,现在的话需要自己在插件市场中找到uview-ui并导入到项目。最终的代码目录结构如下图
因为像微信小程序允许打包后端体积不能超过2M,所以这边使用了分包的方式,采CGColor主要用于CoreGaphics框架之中,CGColor其实是个结构体,而我们通常在使用的CGColor的时候使用的是它的引用类型CGColorRef。CGColor主要由CGColorSapce和Color Components两个部分组成,同样的颜色组成,如果颜色空间不同的话,解析出来的结果可能会有所不同。这就像我们在处理数据的时候,如果把RGBA格式当成BGRA格式处理的结果可想而知。在Quartz 2D中CGColor常用来设置context的填充颜色,设置透明度等。用分包就可以允许20M,
最终整体的运行效果如下
路NSLog(@"cicolor colorspace: %@", ciColor.colorSpace);线规划
公交实时查询
附近信息
目前小程序已经上线,二维码如下
有问题可以直接在小程序中的在线咨询,本章只是简单的展示效果,后续有时间会把开发历程写出来哈~
ios开发UIColor,CGColor,CIColor三者的区别和联系
一、UIColorUIColor是UIKit中存储颜色信息的一个重要的类,一个UIColor对象包含了颜色和透明度的值,它的颜色空间已经针对IOS进行了优化。UIColor包含了一些类方法用于创建一些最常见的颜色,如白色,黑色,红色,透明色等,这些颜色的色彩空间也不尽相同(白色和黑色是kCGColorSpaceDevGray,红色的色彩空间是kCGColorSpaceDevRGB)。
此外UIColor还有两个重要的属性:一个是CGColor,一个是CIColor(5.0之后添加)。这两个属性就可以把UIColor,CGColor,CIColor三个对象联系起来了,后面会详细介绍这三者之间的转换。
二、CGColor
CGColor主要用于CoreGaphics框架之中,CGColor其实是个结构体,而我们通常在使用的CGColor的时候使用的是它的引用类型CGColorRef。CGColor主要由CGColorSapce和Color
Components两个部分组成,同样的颜色组成,如果颜色空间不同的话,解析出来的结果可能会有所不同。这就像我们在处理数据的时候,如果把RGBA格式当成BGRA格式处理的结果可想而知。在Quartz
2D中CGColor常用来设置context的填充颜色,设置透明度等。
1、如何创建一个CGColor,最常用的函数是CGColorCreate,该函数有两个参数:
1) colorspace,指定CGColor对应的颜色空间,Quartz就会retain该对象,因此调用完之后你就可以安全的释放该对象。
该函数该返回一个新创建的CGColorRef,当我们不再使用该对象的时候使用CGColorRelease函数释放该对象。
2、获取CGColor的NSLog(@"color space: %@", colorSpace);数据
在我们创建的时候传入两个重要的参数进去,当我们获取到了CGColorRef以后当然就可以拿到对应的ColorSpace以及Components。
1) 获取ColorSpace
通过CGColorGetColorSpace函数我们可以获取到当前CGColorRef对应的ColorSpace,该函数只接受一个参数就是你要获取ColorSpace的CGColorRef。下面请看一个简单的例子:
CGColorRef cgColor = [UIColor redColor].CGColor;
CGColorSpaceRef colorSpace = CGColorGetColorSpace(cgColor);
2) 获取Color Components
要获取到CGColorRef对应的颜色值,我们需要用到CGColorGetNumberOfComponents和CGColorGetComponents两个函数。我们先来看看两个函数的函数原型:
size_t CGColorGetNumberOfComponents (
);
const CGFloat CGColorGetComponents (
);
个函数是获得CGColorRef的中包含的颜色组成部分的个数,第二个函数就是获取实际的颜色组成部分的数组,下面看一个小例子:
NSUInteger num = CGColorGetNumberOfComponents(cgColor);
const CGFloat colorComponents = CGColorGetComponents(cgColor);
for (int i = 0; i < num; ++i) {
NSLog(@"color components %d: %f", i, colorComponents[i]);
}三、CIColor
CIColor主要是用于和Core
Image框架中其他类,比如CIFilter,CIContext以及CIImage。今天我们主要关心的颜色值部分,CIColor中颜色值的范围是0.0-1.0之间,0.0代表该颜色分量为最小值,1.0代表改颜色分量为值。其中alpha值的范围也是0.0到1.0之间,0.0代表全透明,1.0代表完全不透明,同时CIColor的颜色分量通常都是没有乘以alpha值。
我们可以使用initWithCGColor:函数,通过CGColor创建一个CIColor。其中传入的CGColorRef对象可以使任何任何颜色空间,但是Core
Image框架会在传入filter kernel之前把所有的颜色空间转换到core image工作颜色空间。core
image工作颜色空间使用三个颜色分量加上一个alpha分量组成(其实就是kCGColorSpaceDevRGB),后面的例子中我们验证这一点。
四、UIColor,CGColor,CIColor的区别和联系
1、UIColor的两个属性CGColor,CIColor
UIColor的CGColor总是有效的,不管它是通过CGColor,CIColor,还是其他方法创建的,CGColor属性都总是有效的;但是CIColor属性就不总是有效的,只有当UIColor是通过CIColor创建的时候,他才是有效的,否则访问该属性将会抛出异常,下面照旧来一个小例子:
// test init uicolor with CGColor
UIColor color = [UIColor colorWithCGColor:[UIColor whiteColor].CGColor];
// CGColor property is always valid
NSLog(@"CGColor from UIColor %@", color.CGColor);
// don't use CIColor property
// This property throws an exception if the color object was not initialized with a Core Image color.
NSLog(@"CIColor from UIColor %@", color.CIColor); // crush
2、UIColor使用CGColor初始化
当UIColor使用CGColor初始化的时候,所有CGColorRef包含的信息,都会被原封不动的保留,其中就包括Color
space,而且通过下面的小例子我们还可以看到如果使用CGColor初始化UIColor的时候,UIColor其实是直接保留了一份这个CGColorRef对象。例子如下:
// test kCGColorSCGColorRef colorpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
// color with CGColor, uicolor will just retain it
UIColor color = [UIColor colorWithCGColor:colorCMYK];
NSLog(@"CGColor from UIColor: %@", color.CGColor);
3、UIColor使用CIColor初始化
下面我们讨论一下当使用CIColor来初始化一个UIColor的时候,再去访问UIColor的CGColor属性的时候,我们会发现CGColor的color
Space和设置CIColor的color
space的是不完全一样的,在这个过程中CIColor会为我们做一个转换。下面我们分别看看使用kCGColorSpaceDevGray,kCGColorSpaceDevRGB,kCGColorSpaceDevCMYK三种颜色空间来初始化一个CIColor的时候,再去使用该CIColor去初始化一个UIColor,然后在去访问其CIColor属,CGColor属性,查看颜色空间并打印颜色信息。
1) 使用kCGColorSpaceDevGray初始化CIColor
首先看代码:
// test kCGColorSpaceDevGray
NSLog(@"CGColor white color:%@", [UIColor whiteColor].CGColor);
CIColor ciColor = [CIColor colorWithCGColor:[UIColor whiteColor].CGColor];
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
// Core Image converts all color spaces to the Core Image working color
// space before it passes the color space to the filter kernel.
// kCGColorSpaceDevGray ---> kCGColorSpaceDevRGB
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);
通过运行程序,我们看出来,如果使用一个kCGColorSpaceDevGray的颜色空间的CGColor来初始化CIColor的时候,我们可以看到CIColor的色彩空间一直是kCGColorSpaceDevGray,通过访问UIColor的CIColor属性,我们可以看到其颜色空间仍然是kCGColorSpaceDevGray,但是当访问UIColor的CGColor属性的时候,通过打印可以发现其色彩空间已经转变成了kCGColorSpaceDevRGB空间了,而颜色值也正确的从原来的颜色空间转换到了新的颜色空间。
同样的我们看代码:
//test kCGColorSpaceDevRGB
CIColor ciColor = [CIColor colorWithCGColor:[UIColor redColor].CGColor];
UIColor color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);
整个过程中CIColor,以及通过UIColor的CGColor和CIColor属性访问到的值,打印出来我们可以发现它们都是kCGColorSpaceDevRGB空间的。
4、使用kCGColorSpaceDevCMYK初始化CIColor
下面继续看一段代码:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
NSLog(@"Components number: %zu", CGColorSpaceGetNumberOfComponents(cmykSpace));
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
ciColor = [CIColor colorWithCGColor:colorCMYK];
NSLog(@"cicolor: %@", ciColor); // in fact,the color value of CIColor has converted to RGB Colorspace
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"UIColor with CIColor: %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
// when UIColor init with CIColor, UIColor's CGColor will convert other colorspace to kCGColorSpaceDevRGB
NSLog(@"cgcolor from UIColor: %@", color.CGColor);
整个过程中,我们通过运行同样可以发现,当我们用一个CMYK颜色空间的CGColor来初始化CIColor的时候,CIColor的颜色空间依然是CMYK,但是颜色值已经转换成RGB的颜色值。当使用该CIColor创建一个UIColor的时候,我们再通过CIColor和CGColor属性打印信息的时候,我们会发现CIColor的色彩空间依然是CMYK,但是CGColor打印所得到的信息说明它已经被转换成RGB空间了。
五、UIColor延伸,如何判断两个颜色是否相等
前面提到一点,不管UIColor使用CIColor,CGColor还是其他方式初始化的,其CGColor属性都是可用的。CoreGraphics中提供一个方法可以判断两个CGColor是否相等,因此我们可以通过判断两个UIColor是否相等,下面是看一个简单的例子:
if (CGColorEqualToColor([UIColor whiteColor].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}if (CGColorEqualToColor([UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}例子中部分是判断两个白色的UIColor是否相等,虽然都是白色,但是颜色空间是不一样的,通过运行我们可以发现,打印出“The
two CGColor is not
equal!”。例子的第二部分简单的创建了两个RGB空间的UIColor,运行程序可以看出,这两种颜色是相同的。
ios开发UIColor,CGColor,CIColor三者的区别和联系
2) components,一个CGFloat的数组,该数组的元素个数是指定色彩空间包含的颜色分量数n,加上对应的alpha值。最近看了看CoreGraphics的东西,看到关于CGColor的东西,于是就想着顺便看看UIColor,CIColor,弄清楚它们之间的区别和联系。下面我们分别看看它们三个的概念:
UIColor是UIKit中存储颜色信息的一个重要的类,一个UIColor对象包含了颜色和透明度的值,它的颜色空间已经针对IOS进行了优化。UIColor包含了一些类方法用于创建一些最常见的颜色,如白色,黑色,红色,透明色等,这些颜色的色彩空间也不尽相同(白色和黑色是kCGColorSpaceDevGray,红色的色彩空间是kCGColorSpaceDevRGB)。
此外UIColor还有两个重要的属性:一个是CGColor,一个是CIColor(5.0之后添加)。这两个属性就可以把UIColor,CGColor,CIColor三个对象联系起来了,后面会详细介绍这三者之间的转换。
二、CGColor
1、如何创建一个CG首页Color,最常用的函数是CGColorCreate,该函数有两个参数:
1) colorspace,指定CGColor对应的颜色空间,Quartz就会retain该对象,因此调用完之后你就可以安全的释放该对象。
该函数该返回一个新创建的CGColorRef,当我们不再使用该对象的时候使用CGColorRelease函数释放该对象。
2、获取CGColor的数据
在我们创建的时候传入两个重要的参数进去,当我们获取到了CGColorRef以后当然就可以拿到对应的ColorSpace以及Components。
1) 获取ColorSpace
通过CGColorGetColorSpace函数我们可以获取到当前CGColorRef对应的ColorSpace,该函数只接受一个参数就是你要获取ColorSpace的CGColorRef。下面请看一个简单的例子:
CGColorRef cgColor = [UIColor redColor].CGColor;
CGColorSpaceRef colorSpace = CGColorGetColorSpace(cgColor);
要获取到CGColorRef对应的颜色值,我们需要用到CGColorGetNumberOfComponents和CGColorGetComponents两个函数。我们先来看看两个函数的函数原型:
size_t CGColorGetNumberOfComponents (
);
const CGFloat CGColorGetComponents (
NSUInteger num = CGColorGetNumberOfComponents(cgColor);
const CGFloat colorComponents = CGColorGetComponents(cgColor);
for (int i = 0; i < num; ++i) {
NSLog(@"color components %d: %f", i, colorComponents[i]);
}三、CIColor
CIColor主要是用于和Core Image框架中其他类,比如CIFilter,CIContext以及CIImage。今天我们主要关心的颜色值部分,CIColor中颜色值的范围是0.0-1.0之间,0.0代表该颜色分量为最小值,1.0代表改颜色分量为值。其中alpha值的范围也是0.0到1.0之间,0.0代表全透明,1.0代表完全不透明,同时CIColor的颜色分量通常都是没有乘以alpha值。
我们可以使用initWithCGColor:函数,通过CGColor创建一个CIColor。其中传入的CGColorRef对象可以使任何任何颜色空间,但是Core Image框架会在传入filter kernel之前把所有的颜色空间转换到core image工作颜色空间。core image工作颜色空间使用三个颜色分量加上一个alpha分量组成(其实就是kCGColorSpaceDevRGB),后面的例子中我们验证这一点。
四、UIColor,CGColor,CIColor的区别和联系
1、UIColor的两个属性CGColor,CIColor
UIColor的CGColor总是有效的,不管它是通过CGColor,CIColor,还是其他方法创建的,CGColor属性都总是有效的;但是CIColor属性就不总是有效的,只有当UIColor是通过CIColor创建的时候,他才是有效的,否则访问该属性将会抛出异常,下面照旧来一个小例子:
// test init uicolor with CGColor
UIColor color = [UIColor colorWithCGColor:[UIColor whiteColor].CGColor];
// CGColor property is always valid
NSLog(@"CGColor from UIColor %@", color.CGColor);
// don't use CIColor property
// This property throws an exception if the color object was not initialized with a Core Image color.
NSLog(@"CIColor from UIColor %@", color.C2) 使用kCGColorSpaceDevRGB初始化CIColorIColor); // crush2、UIColor使用CGColor初始化
当UIColor使用CGColor初始化的时候,所有CGColorRef包含的信息,都会被原封不动的保留,其中就包括Color space,而且通过下面的小例子我们还可以看到如果使用CGColor初始化UIColor的时候,UIColor其实是直接保留了一份这个CGColorRef对象。例子如下:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
// color with CGColor, uicolor will just retain it
UIColor color = [UIColor colorWithCGColor:colorCMYK];
NSLog(@"CGColor from UIColor: %@", color.CGColor);3、UIColor使用CIColor初始化
1) 使用kCGColorSpaceDevGray初始化CIColor
首先看代码:
// test kCGColorSpaceDevGray
NSLog(@"CGColor white color:%@", [UIColor whiteColor].CGColor);
CIColor ciColor = [CIColor colorWithCGColor:[UIColor whiteColor].CGColor];
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
// Core Image converts all color spaces to the Core Image working color
// space before it passes the color space to the filter kernel.
// kCGColorSpaceDevGray ---> kCGColorSpaceDevRGB
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);通过运行程序,我们看出来,如果使用一个kCGColorSpaceDevGray的颜色空间的CGColor来初始化CIColor的时候,我们可以看到CIColor的色彩空间一直是kCGColorSpaceDevGray,通过访问UIColor的CIColor属性,我们可以看到其颜色空间仍然是kCGColorSpaceDevGray,但是当访问UIColor的CGColor属性的时候,通过打印可以发现其色彩空间已经转变成了kCGColorSpaceDevRGB空间了,而颜色值也正确的从原来的颜色空间转换到了新的颜色空间。
同样的我们看代码:
//test kCGColorSpaceDevRGB
CIColor ciColor = [CIColor colorWithCGColor:[UIColor redColor].CGColor];
UIColor color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);整个过程中CIColor,以及通过UIColor的CGColor和CIColor属性访问到的值,打印出来我们可以发现它们都是kCGColorSpaceDevRGB空间的。
4、使用kCGColorSpaceDevCMYK初始化CIColor
下面继续看一段代码:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
NSLog(@"Components number: %zu", CGColorSpaceGetNumberOfComponents(cmykSpace));
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
ciColor = [CIColor colorWithCGColor:colorCMYK];
NSLog(@"cicolor: %@", ciColor); // in fact,the color value of CIColor has converted to RGB Colorspace
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"UIColor with CIColor: %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
// when UIColor init with CIColor, UIColor's CGColor will convert other colorspace to kCGColorSpaceDevRGB
NSLog(@"cgcolor from UIColor: %@", color.CGColor);整个过程中,我们通过运行同样可以发现,当我们用一个CMYK颜色空间的CGColor来初始化CIColor的时候,CIColor的颜色空间依然是CMYK,但是颜色值已经转换成RGB的颜色值。当使用该CIColor创建一个UIColor的时候,我们再通过CIColor和CGColor属性打印信息的时候,我们会发现CIColor的色彩空间依然是CMYK,但是CGColor打印所得到的信息说明它已经被转换成RGB空间了。
五、UIColor延伸,如何判断两个颜色是否相等
前面提到一点,不管UIColor使用CIColor,CGColor还是其他方式初始化的,其CGColor属性都是可用的。CoreGraphics中提供一个方法可以判断两个CGColor是否相等,因此我们可以通过判断两个UIColor是否相等,下面是看一个简单的例子:
if (CGColorEqualToColor([UIColor whiteColor].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}if (CGColorEqualToColor([UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}例子中部分是判断两个白色的UIColor是否相等,虽然都是白色,但是颜色空间是不一样的,通过运行我们可以发现,打印出“The two CGColor is not equal!”。例子的第二部分简单的创建了两个RGB空间的UIColor,运行程序可以看出,这两种颜色是相同的。
转载
ios开发UIColor,CGColor,CIColor三者的区别和联系
NSLog(@"CGColor red color:%@", [UIColor redColor].CGColor);UIColor是UIKit中存储颜色信息的一个重要的类,一个UIColor对象包含了颜色和透明度的值,它的颜色空间已经针对IOS进行了优化。UIColor包含了一些类方法用于创建一些最常见的颜色,如白色,黑色,红色,透明色等,这些颜色的色彩空间也不尽相同(白色和黑色是kCGColorSpaceDevGray,红色的色彩空间是kCGColorSpaceDevRGB)。
此外UIColor还有两个重要的属性:一个是CGColor,一个是CIColor(5.0之后添加)。这两个属性就可以把UIColor,CGColor,CIColor三个对象联系起来了,后面会详细介绍这三者之间的转换。
二、CGColor
CGColor主要用于CoreGaphics框架之中,CGColor其实是个结构体,而我们通常在使用的CGColor的时候使用的是它的引用类型CGColorRef。CGColor主要由CGColorSapce和Color
Components两个部分组成,同样的颜色组成,如果颜色空间不同的话,解析出来的结果可能会有所不同。这就像我们在处理数据的时候,如果把RGBA格式当成BGRA格式处理的结果可想而知。在Quartz
2D中CGColor常用来设置context的填充颜色,设置透明度等。
1、如何创建一个CGColor,最常用的函数是CGColorCreate,该函数有两个参数:
1) colorspace,指定CGColor对应的颜色空间,Quartz就会retain该对象,因此调用完之后你就可以安全的释放该对象。
该函数该返回一个新创建的CGColorRef,当我们不再使用该对象的时候使用CGColorRelease函数释放该对象。
2、获取CGColor的数据
在我们创建的时候传入两个重要的参数进去,当我们获取到了CGColorRef以后当然就可以拿到对应的ColorSpace以及Components。
1) 获取ColorSpace
通过CGColorGetColorSpace函数我们可以获取到当前CGColorRef对应的ColorSpace,该函数只接受一个参数就是你要获取ColorSpace的CGColorRef。下面请看一个简单的例子:
CGColorRef cgColor = [UIColor redColor].CGColor;
CGColorSpaceRef colorSpace = CGColorGetColorSpace(cgColor);
2) 获取Color Components
要获取到CGColorRef对应的颜色值,我们需要用到CGColorGetNumberOfComponents和CGColorGetComponents两个函数。我们先来看看两个函数的函数原型:
size_t CGColorGetNumberOfComponents (
);
const CGFloat CGColorGetComponents (
);
个函数是获得CGColorRef的中包含的颜色组成部分的个数,第二个函数就是获取实际的颜色组成部分的数组,下面看一个小例子:
NSUInteger num = CGColorGetNumberOfComponents(cgColor);
const CGFloat colorComponents = CGColorGetComponents(cgColor);
for (int i = 0; i < num; ++i) {
NSLog(@"color components %d: %f", i, colorComponents[i]);
}三、C前言uni-app是一个可以实现多端小程序的框架,可编译成微信小程序,小程序,百度小程序,支付宝小程序,h5网页,安卓app等多个平台,开发者只需要一套代码,就可以运行到各个平台上,如果会vue开发的小伙伴们,就很容易上手。目前uni-app也有很多兼容性非常好的ui框架可以选择,如uview-ui,colorui等等。下面展示就是基于uni-app+uview-ui实现的实时公交车小程序。IColor
CIColor主要是用于和Core
Image框架中其他类,比如CIFilter,CIContext以及CIImage。今天我们主要关心的颜色值部分,CIColor中颜色值的范围是0.0-1.0之间,0.0代表该颜色分量为最小值,1.0代表改颜色分量为值。其中alpha值的范围也是0.0到1.0之间,0.0代表全透明,1.0代表完全不透明,同时CIColor的颜色分量通常都是没有乘以alpha值。
我们可以使用initWithCGColor:函数,通过CGColor创建一个CIColor。其中传入的CGColorRef对象可以使任何任何颜色空间,但是Core
Image框架会在传入filter kernel之前把所有的颜色空间转换到core image工作颜色空间。core
image工作颜色空间使用三个颜色分量加上一个alpha分量组成(其实就是kCGColorSpaceDevRGB),后面的例子中我们验证这一点。
四、UIColor,CGColor,CIColor的区别和联系
1、UIColor的两个属性CGColor,CIColor
UIColor的CGColor总是有效的,不管它是通过CGColor,CIColor,还是其他方法创建的,CGColor属性都总是有效的;但是CIColor属性就不总是有效的,只有当UIColor是通过CIColor创建的时候,他才是有效的,否则访问该属性将会抛出异常,下面照旧来一个小例子:
// test init uicolor with CGColor
UIColor color = [UIColor colorWithCGColor:[UIColor whiteColor].CGColor];
// CGColor property is always valid
NSLog(@"CGColor from UIColor %@", color.CGColor);
// don't use CIColor property
// This property throws an exception if the color object was not initialized with a Core Image color.
NSLog(@"CIColor from UIColor %@", color.CIColor); // crush
2、UIColor使用CGColor初始化
当UIColor使用CGColor初始化的时候,所有CGColorRef包含的信息,都会被原封不动的保留,其中就包括Color
space,而且通过下面的小例子我们还可以看到如果使用CGColor初始下面我们讨论一下当使用CIColor来初始化一个UIColor的时候,再去访问UIColor的CGColor属性的时候,我们会发现CGColor的color Space和设置CIColor的color space的是不完全一样的,在这个过程中CIColor会为我们做一个转换。下面我们分别看看使用kCGColorSpaceDevGray,kCGColorSpaceDevRGB,kCGColorSpaceDevCMYK三种颜色空间来初始化一个CIColor的时候,再去使用该CIColor去初始化一个UIColor,然后在去访问其CIColor属,CGColor属性,查看颜色空间并打印颜色信息。化UIColor的时候,UIColor其实是直接保留了一份这个CGColorRef对象。例子如下:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
// color with CGColor, uicolor will just retain it
UIColor color = [UIColor colorWithCGColor:colorCMYK];
NSLog(@"CGColor from UIColor: %@", color.CGColor);
3、UIColor使用CIColor初始化
下面我们讨论一下当使用CIColor来初始化一个UIColor的时候,再去访问UIColor的CGColor属性的时候,我们会发现CGColor的color
Space和设置CIColor的color
space的是不完全一样的,在这个过程中CIColor会为我们做一个转换。下面我们分别看看使用kCGColorSpaceDevGray,kCGColorSpaceDevRGB,kCGColorSpaceDevCMYK三种颜色空间来初始化一个CIColor的时候,再去使用该CIColor去初始化一个UIColor,然后在去访问其CIColor属,CGColor属性,查看颜色空间并打印颜色信息。
1) 使用kCGColorSpaceDevGray初始化CIColor
首先看代码:
// test kCGColorSpaceDevGray
NSLog(@"CGColor white color:%@", [UIColor whiteColor].CGColor);
CIColor ciColor = [CIColor colorWithCGColor:[UIColor whiteColor].CGColor];
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
// Core Image converts all color spaces to the Core Image working color
// space before it passes the color space to the filter kernel.
// kCGColorSpaceDevGray ---> kCGColorSpaceDevRGB
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);
通过运行程序,我们看出来,如果使用一个kCGColorSpaceDevGray的颜色空间的CGColor来初始化CIColor的时候,我们可以看到CIColor的色彩空间一直是kCGColorSpaceDevGray,通过访问UIColor的CIColor属性,我们可以看到其颜色空间仍然是kCGColorSpaceDevGray,但是当访问UIColor的CGColor属性的时候,通过打印可以发现其色彩空间已经转变成了kCGColorSpaceDevRGB空间了,而颜色值也正确的从原来的颜色空间转换到了新的颜色空间。
同样的我们看代码:
//test kCGColorSpaceDevRGB
CIColor ciColor = [CIColor colorWithCGColor:[UIColor redColor].CGColor];
UIColor color = [UIColor colorWithCIColor:ciColor];
NSLog(@"color %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
NSLog(@"color's CGColor: %@", color.CGColor);
整个过程中CIColor,以及通过UIColor的CGColor和CIColor属性访问到的值,打印出来我们可以发现它们都是kCGColorSpaceDevRGB空间的。
4、使用kCGColorSpaceDevCMYK初始化CIColor
下面继续看一段代码:
// test kCGColorSpaceDevCMYK
CGColorSpaceRef cmykSpace = CGColorSpaceCreateDevCMYK();
NSLog(@"Components number: %zu", CGColorSpaceGetNumberOfComponents(cmykSpace));
CGFloat cmykValue[] = {1, 1, 0, 0, 1}; // blue
CGColorSpaceRelease(cmykSpace);
NSLog(@"colorCMYK: %@", colorCMYK);
ciColor = [CIColor colorWithCGColor:colorCMYK];
NSLog(@"cicolor: %@", ciColor); // in fact,the color value of CIColor has converted to RGB Colorspace
color = [UIColor colorWithCIColor:ciColor];
NSLog(@"UIColor with CIColor: %@", color);
NSLog(@"cicolor from UIColor: %@", color.CIColor);
NSLog(@"cicolor's colorspace: %@", color.CIColor.colorSpace);
// when UIColor init with CIColor, UIColor's CGColor will convert other colorspace to kCGColorSpaceDevRGB
NSLog(@"cgcolor from UIColor: %@", color.CGColor);
整个过程中,我们通过运行同样可以发现,当我们用一个CMYK颜色空间的CGColor来初始化CIColor的时候,CIColor的颜色空间依然是CMYK,但是颜色值已经转换成RGB的颜色值。当使用该CIColor创建一个UIColor的时候,我们再通过CIColor和CGColor属性打印信息的时候,我们会发现CIColor的色彩空间依然是CMYK,但是CGColor打印所得到的信息说明它已经被转换成RGB空间了。
五、UIColor延伸,如何判断两个颜色是否相等
前面提到一点,不管UIColor使用CIColor,CGColor还是其他方式初始化的,其CGColor属性都是可用的。CoreGraphics中提供一个方法可以判断两个CGColor是否相等,因此我们可以通过判断两个UIColor是否相等,下面是看一个简单的例子:
if (CGColorEqualToColor([UIColor whiteColor].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}if (CGColorEqualToColor([UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor, [UIColor colorWithRed:1 green:1 blue:1 alpha:1].CGColor)) {
}else {
NSLog(@"The two CGColor is not equal!");
}例子中部分是判断两个白色的UIColor是否相等,虽然都是白色,但是颜色空间是不一样的,通过运行我们可以发现,打印出“The
two CGColor is not
equal!”。例子的第二部分简单的创建了两个RGB空间的UIColor,运行程序可以看出,这两种颜色是相同的。
基于uni-app开发的实时公交车小程序
CGColorRef colorCMYK = CGColorCreate(cmykSpace, cmykValue);NSLog(@"The two CGColor is equal!");首先使用hbuild开发工具新建一个uni-app项目,早期版本的hbuild有uview-ui可以直接导入,现在的话需要自己在插件市场中找到uview-ui并导入到项目。最终的代码目录结构如下图
因为像微信小程序允许打包后端体积不能超过2M,所以这边使用了分包的方式,采用分包就可以允许20M,
最终整体的运行效果如下
路线规划
公交实时查询
附近信息
目前小程序已经上线,二维码如下
有问题可以直接在小程序中的在线咨询,本章只是简单的展示效果,后续有时间会把开发NSLog(@"The two CGColor is equal!");历程写出来哈~
吴亚馨 康熙来了 大s和小s

您好,今天小深来为大家解答以上的问题。吴亚馨 康熙来了相信很多小伙伴还不知道,现在让我们一起来看看吧! 吴亚馨 康熙来了 大s和小s 吴亚馨 康熙来了 大s和小s 吴亚馨 康熙来了 大s和小s 1、···
百度地图车机 百度地图车机大屏版

腾势300用什么导航 百度地图车机在使用百度地图进行导航时,车道级导航是非常重要如果你的车机系统上已经有高德地图车机版了,那么就可以使用高德地图的车机互联功能,用高德地图手机版扫···
鸭肾怎么炒好吃_鸭肾怎么炒好吃视频

鸭肾炒青椒的做法步骤图,鸭肾炒青椒怎么做 1.鸭肾洗净切片;瑶柱用清水浸软;冬瓜洗净切块。 1、准备好鸡肾和青辣椒,姜,蒜头。进行处理,鸡肾切好,辣椒切好,等等。 鸭肾怎么炒好吃_鸭···