- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
给定 CGImage 或 UIImage,我如何应用自定义颜色查找表(也称为 LUT、CLUT、颜色映射)?也就是说,如何在给定映射的情况下将图像中的颜色映射到新颜色?
最佳答案
我将描述您可以采用的三种方法。
首先,从 UIImage 中获取原始图像数据。您可以通过创建一个适当大小(宽度 * 高度 * 组件)的字节数组,然后使用 CGBitmapContext 绘制到它来完成此操作。像这样:
using (var colorSpace = CGColorSpace.CreateDeviceRGB())
using (var context = new CGBitmapContext(
bytes, width, height, bitsPerComponent, bytesPerRow,
colorSpace, CGBitmapFlags.ByteOrder32Big | CGBitmapFlags.PremultipliedLast))
{
var drawRect = new RectangleF(-rectangle.X, -rectangle.Y, image.CGImage.Width, image.CGImage.Height);
context.ClipToRect(new RectangleF(0, 0, width, height));
context.DrawImage(drawRect, image.CGImage);
}
然后为输出图像创建一个字节数组(可能大小相同)。遍历输入图像,在查找表中查找颜色值并将它们写入输出图像。
您可以通过从字节构造一个CGDataProvider
,然后从中构造一个CGImage
,然后构造一个UIImage
,将输出字节转换为图像> 来自 CGImage
。
从 iOS 5 开始,Apple 提供了许多内置的图像操作。一般来说,这些比手动操作更容易使用并且更快。但是,根据您的颜色查找表的指定方式,您可能找不到最合适的。
给定一个 CIFilter,您可以设置 inputImage,然后从 OutputImage
属性中检索输出。查看documentation获取 CICategoryColorAdjustment 和 CICategoryColorEffect 类别中的过滤器列表。在撰写本文时,我建议查看 CIToneCurve、CIFalseColor、CIColorMap 和 CIColorCube。遗憾的是,在撰写本文时,CIColorMap 在 iOS 上不可用。
如果您正在进行科学成像,并且只在两种颜色之间使用线性渐变,我建议您查看 CIFalseColor。
这是一个使用随机颜色查找函数填充 CIColorCube 的示例。请注意,CIFilters 可以通过名称(不是类型安全的)或以强类型的方式动态创建。如果您知道要在代码时使用什么过滤器,我建议使用强类型过滤器(CIColorCube
而不是 CIFilter.FromName("CIColorCube")
)。我在下面的例子中使用了动态方法,因为它更容易混淆。
static void PopulateColorCubeFilter(CIFilter filter)
{
if (filter.Name != "CIColorCube")
return;
int dimension = 64; // Must be power of 2, max of 128 (max of 64 on ios)
int cubeDataSize = 4 * dimension * dimension * dimension;
filter[new NSString("inputCubeDimension")] = new NSNumber(dimension);
// 2 : 32 /4 = 8 = 2^3
// 4 : 256 /4 = 64 = 4^3
// 8 : 2048 /4 = 512 = 8^3
var cubeData = new byte[cubeDataSize];
var rnd = new Random();
rnd.NextBytes(cubeData);
for (int i = 3; i < cubeDataSize; i += 4)
cubeData[i] = 255;
filter[new NSString("inputCubeData")] = NSData.FromArray(cubeData);
}
最后,在放大下保持正确的最通用的高性能方法是在 GPU 上进行颜色映射。这比前两种方法更费力,因此您需要决定它是否值得。
关于c# - 如何将 LUT(颜色查找表)应用于 IOS 中的 CGImage 或 UIImage?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11258323/
我正在尝试将 cgImage 从旧函数转换为新函数,但我不确定最后一个参数的参数应该是什么。基于旧函数的 param alphaType: 参数为 .alphaIsOne,新参数 param isOp
我尝试通过填写自己的数据来创建 UIImage。到目前为止一切正常。但是,如果我尝试多次调用此函数,它似乎会填满内存,直到应用程序崩溃。使用 VM Tracker,我发现当应用程序崩溃时,脏内存会增长
这是 Apple 的代码(来自技术问答 QA1702),用于从视频缓冲区获取 UIImage。不幸的是,返回的图像旋转了 90 度。如何编辑它以使返回的图像方向正确? - (UIImage *) im
使用标准图像格式(jpeg、gif、png 等)从文件加载 CGImage 或 NSImage 非常简单。 但是,我现在需要从使用 libfreetype 生成的内存中的字节数组创建 CGImage。
我正在使用 CIBloom 模糊 CGImage 中的一些文本,但发生的情况是 CIBloom 过滤器似乎使我的图像变得非常小 . 当滤波器内核变大时效果更差。我有点预料到这一点,但我需要一种方法来关
我有一个内存泄漏,我只是不知道如何解决。 这是泄露的代码: [newImg release]; CGColorSpaceRef d_colorSpace = CGColorSpaceCreateDev
在 iOS 4.0 及更高版本中,有没有一种方法可以在不将整个图像加载到内存的情况下对 CGImage 进行分割?我试图做的是*以编程方式*分割图像,以便在使用大图像的 CATiledLayer 应用
在我的应用中,我想生成一个视频的多个缩略图,最好是质量好的缩略图。我的旧方法是执行一个循环 15 次,并在不同的时间复制一个 CGImage。如下图 func generateThumbnails(_
一种方法是: CGImageRef scaledImage(CGImageref, destination rect) { context = CGBitmapContextCreate(re
我有一个 UIView 子类,它呈现应用了 mask 的图像。它在所有设备(仅限 iPad)上都能完美运行,除了那些具有宽色域显示屏(最新的 iPad Pro)的设备,在这些设备上, mask 呈现完
我正在为 mac 开发一个类似放大镜的应用程序。我的目标是能够在放大时精确定位单个像素。我在 mouseMoved(with event: NSEvent) 中使用此代码: let captureSi
我希望将一个 CGImage 覆盖在另一个之上。 作为示例,第一个 CGImage 为 1024x768,并且想要在给定位置覆盖第二个 100x100 CGImage。 我已经了解了如何使用 NSIm
所以我一直在开发一个小的“绘图”应用程序,用户可以在网格 Canvas 上绘制图像(基本上创建像素艺术)。我想创建一个导出此 Canvas 的函数(将其视为 UIColor 数组,然后将其转换为 Ra
有没有一种方法可以在 iOS 中将原始图像数据存储和加载到磁盘上,以节省解压时间和内存并减少应用程序的脏内存占用? 保罗·哈达德已hinting to something like this我知道这项
我有一个手绘 View (用户可以用手指画线)。我只使用几种颜色,所以我有一个我写的压缩算法(想通过本地网络将它发送到另一台 iPad)但我似乎无法准确地从图形上下文中获取数据,即使使用这个简单的测试
我正在尝试编写一段代码来判断 CGPoint 是否位于图像的黑色区域内(成功的答案是 here )。在我的实现中,如果使用此代码触摸点为黑色,我可以成功返回 NSLog: -(void)touches
我正在通过网络连接接收一系列图像,并希望尽快显示它们,最高可达 30 FPS。我派生了一个 UIView 对象(因此我可以覆盖 drawRect)并公开了一个名为 cameraImage 的 UIIm
我有以下代码: UIImage *img = [UIImage imageNamed:@"BRBlueCircleMask"]; CGImageRef activeCirleMaskImage = i
对于物理缩放任何 UIImage 的方法,我需要创建位图上下文,它具有与图像完全相同的设置,除了目标宽度和高度。 到目前为止,这是我的代码。缺少什么:如何为 CGBitmapContextCreate
我有一个图像,其 RGB 分量是全白的,具有不同的 alpha -- 例如,RGBA 格式的 0xFFFFFF09。但是,当我使用 UIImage 或 CGImage API 加载此图像,然后在 CG
我是一名优秀的程序员,十分优秀!