public RemapHueCommand()
- (instancetype)init
public RemapHueCommand();
public:
RemapHueCommand();
__init__() # Default constructor
Run the RemapHueCommand on an image and change all green hues (and hues near green).
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing.Color;
public int INCREMENT_S2(int x, int Length)
{
return ((x + 1) % Length);
}
public int DECREMENT_S2(int x, int Length)
{
return ((x + (Length - 1)) % Length);
}
public int ADD_S2(int x, int y, int Length)
{
return ((x + y) % Length);
}
public void RemapHueCommandConstructorExample()
{
// Load an image
RasterCodecs codecs = new RasterCodecs();
codecs.ThrowExceptionsOnInvalidImages = true;
RasterImage image = codecs.Load(Path.Combine(LEAD_VARS.ImagesDir, "cannon.jpg"));
// Prepare the command
int Length;
if (image.BitsPerPixel >= 48)
Length = 0x10000;
else if (!(image.BitsPerPixel == 16 || image.BitsPerPixel == 12))
Length = 256;
else if (image.GetLookupTable() != null && image.UseLookupTable)
Length = 256;
else
Length = (1 << image.BitsPerPixel);
//Allocate tables
int[] MaskTable = new int[Length];
int[] HueTable = new int[Length];
//Initialize tables
for (int i = 0; i < Length; i++)
{
MaskTable[i] = 0;
HueTable[i] = i;
}
//Get the hue for green
RasterHsvColor hsvRef = RasterHsvColor.FromRasterColor(new RasterColor(0, 255, 0));
int HueGreen = hsvRef.H;
//Obtain new hue
hsvRef = RasterHsvColor.FromRasterColor(new RasterColor(255, 128, 0));
int Change = (int)hsvRef.H - (int)HueGreen;
int HueChange = (Change > 0) ? (int)Change : (int)(Change + Length - 1);
HueGreen *= (Length - 1) / 255;
HueChange *= (Length - 1) / 255;
//Set values in HueTable, MaskTable
HueTable[HueGreen] = (HueTable[HueGreen] + HueChange);
MaskTable[HueGreen] = 1;
//set the hues near green (+/- 15)
int Count = (15 * (Length - 1)) / 255;
for (int i = INCREMENT_S2(HueGreen, Length); Count > 0; i = INCREMENT_S2(i, Length), Count--)
{
HueTable[i] = ADD_S2(HueTable[i], HueChange, Length);
MaskTable[i] = 1;
}
Count = (15 * (Length - 1)) / 255;
for (int i = DECREMENT_S2(HueGreen, Length); Count > 0; i = DECREMENT_S2(i, Length), Count--)
{
HueTable[i] = ADD_S2(HueTable[i], HueChange, Length);
MaskTable[i] = 1;
}
RemapHueCommand command = new RemapHueCommand();
command.Mask = MaskTable;
command.HueTable = HueTable;
command.SaturationTable = null;
command.ValueTable = null;
command.LookUpTableLength = Length;
command.Run(image);
codecs.Save(image, Path.Combine(LEAD_VARS.ImagesDir, "Result.jpg"), RasterImageFormat.Jpeg, 24);
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";
}
import static org.junit.Assert.assertTrue;
import java.io.File;
import java.io.IOException;
import org.junit.*;
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
import leadtools.*;
import leadtools.codecs.*;
import leadtools.imageprocessing.color.*;
public int INCREMENT_S2(int x, int Length) {
return ((x + 1) % Length);
}
public int DECREMENT_S2(int x, int Length) {
return ((x + (Length - 1)) % Length);
}
public int ADD_S2(int x, int y, int Length) {
return ((x + y) % Length);
}
public void remapHueCommandConstructorExample() {
final String LEAD_VARS_IMAGES_DIR = "C:\\LEADTOOLS23\\Resources\\Images";
// Load an image
RasterCodecs codecs = new RasterCodecs();
codecs.setThrowExceptionsOnInvalidImages(true);
RasterImage image = codecs.load(combine(LEAD_VARS_IMAGES_DIR, "cannon.jpg"));
// Prepare the command
int[] maskTable;
int[] hueTable;
RasterHsvColor hsvRef;
int hueGreen, hueChange;
int change;
int i, count;
int length;
if (image.getBitsPerPixel() >= 48)
length = 0x10000;
else if (!(image.getBitsPerPixel() == 16 || image.getBitsPerPixel() == 12))
length = 256;
else if (image.getLookupTable() != null && image.getUseLookupTable())
length = 256;
else
length = (1 << image.getBitsPerPixel());
// Allocate tables
maskTable = new int[length];
hueTable = new int[length];
// Initialize tables
for (i = 0; i < length; i++) {
maskTable[i] = 0;
hueTable[i] = i;
}
// Get the hue for green
hsvRef = RasterHsvColor.fromRasterColor(new RasterColor(0, 255, 0));
hueGreen = hsvRef.getH();
// Obtain new hue
hsvRef = RasterHsvColor.fromRasterColor(new RasterColor(255, 128, 0));
change = (int) hsvRef.getH() - (int) hueGreen;
hueChange = (change > 0) ? (int) change : (int) (change + length - 1);
hueGreen *= (length - 1) / 255;
hueChange *= (length - 1) / 255;
// Set values in HueTable, MaskTable
hueTable[hueGreen] = (hueTable[hueGreen] + hueChange);
maskTable[hueGreen] = 1;
// Set the hues near green (+/- 15)
count = (15 * (length - 1)) / 255;
for (i = INCREMENT_S2(hueGreen, length); count > 0; i = INCREMENT_S2(i, length), count--) {
hueTable[i] = ADD_S2(hueTable[i], hueChange, length);
maskTable[i] = 1;
}
count = (15 * (length - 1)) / 255;
for (i = DECREMENT_S2(hueGreen, length); count > 0; i = DECREMENT_S2(i, length), count--) {
hueTable[i] = ADD_S2(hueTable[i], hueChange, length);
maskTable[i] = 1;
}
RemapHueCommand command = new RemapHueCommand(maskTable, hueTable, null, null, length);
command.run(image);
codecs.save(image, combine(LEAD_VARS_IMAGES_DIR, "Result.jpg"), RasterImageFormat.JPEG, 24);
System.out.println("Command run and image saved to " + combine(LEAD_VARS_IMAGES_DIR, "Result.jpg"));
assertTrue("Command run and image saved", (new File(combine(LEAD_VARS_IMAGES_DIR, "Result.jpg")).exists()));
}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document