Класс ColorPaletteHelper

Содержание
[ ]

Summary: Helper class for color palettes manipulation.

Module: aspose.imaging

Full Name: aspose.imaging.ColorPaletteHelper

Methods

NameDescription
create_4_bit()Создает 4-битовую цветовую палитру.
create_4_bit_grayscale(min_is_white)Создает 4-битовую палитру градаций серого.
create_8_bit()Создает 8-битовую цветовую палитру.
create_8_bit_grayscale(min_is_white)Создает 8-битовую палитру градаций серого.
create_grayscale(bits)Получает градационную палитру указанного количества бит. Допустимые значения бит: 1, 2, 4, 8.
create_monochrome()Создаёт монохромную цветовую палитру, содержащую только 2 цвета.
get_close_image_palette(image, dest_bounds, entries_count)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_close_image_palette(image, dest_bounds, entries_count, use_image_palette)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_close_image_palette(image, dest_bounds, entries_count, use_image_palette, alpha_blend_in_color)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_close_image_palette(image, dest_bounds, entries_count, use_image_palette, alpha_blend_in_color, keep_transparency)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_close_image_palette(image, entries_count)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_close_image_palette(image, entries_count, palette_mining_method)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Палитра будет оптимизирована для лучшего качества индексированного изображения или оставлена “AS IS”, когда используется PaletteMiningMethod.UseCurrentPalette.
get_close_image_palette_by_method(image, entries_count, palette_mining_method)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Палитра будет оптимизирована для лучшего качества индексированного изображения или оставлена “AS IS”, когда используется PaletteMiningMethod.UseCurrentPalette.
get_close_image_palette_by_rect(image, dest_bounds, entries_count)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_close_transparent_image_palette(image, entries_count)Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.
get_downscale_palette(image)Получить 256‑цветную палитру, составленную из старших битов начальных цветовых значений изображения.
get_uniform_color_palette(image)Получить однородную 256‑цветную палитру.
has_transparent_colors(palette)Определяет, содержит ли указанная палитра прозрачные цвета.

Method: create_4_bit() [static]

 create_4_bit() 

Создает 4-битовую цветовую палитру.

Returns

ТипОписание
IColorPalette4‑битная цветовая палитра.

Method: create_4_bit_grayscale(min_is_white) [static]

 create_4_bit_grayscale(min_is_white) 

Создает 4-битовую палитру градаций серого.

Parameters:

ПараметрТипОписание
min_is_whiteboolесли установлено в true, палитра начинается с белого цвета, иначе начинается с чёрного цвета.

Returns

ТипОписание
IColorPalette4‑битная градационная палитра.

Method: create_8_bit() [static]

 create_8_bit() 

Создает 8-битовую цветовую палитру.

Returns

ТипОписание
IColorPalette8‑битная цветовая палитра.

Method: create_8_bit_grayscale(min_is_white) [static]

 create_8_bit_grayscale(min_is_white) 

Создает 8-битовую палитру градаций серого.

Parameters:

ПараметрТипОписание
min_is_whiteboolесли установлено в true, палитра начинается с белого цвета, иначе начинается с чёрного цвета.

Returns

ТипОписание
IColorPalette8‑битная градационная палитра.

Method: create_grayscale(bits) [static]

 create_grayscale(bits) 

Получает градационную палитру указанного количества бит. Допустимые значения бит: 1, 2, 4, 8.

Parameters:

ПараметрТипОписание
битыintКоличество бит.

Returns

ТипОписание
IColorPaletteГрадационная палитра.

Method: create_monochrome() [static]

 create_monochrome() 

Создаёт монохромную цветовую палитру, содержащую только 2 цвета.

Returns

ТипОписание
IColorPaletteЦветовая палитра для монохромных изображений.

Method: get_close_image_palette(image, dest_bounds, entries_count) [static]

 get_close_image_palette(image, dest_bounds, entries_count) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
dest_boundsRectangleГраницы целевого изображения.
entries_countintЖелаемое количество элементов.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_close_image_palette(image, dest_bounds, entries_count, use_image_palette) [static]

 get_close_image_palette(image, dest_bounds, entries_count, use_image_palette) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
dest_boundsRectangleГраницы целевого изображения.
entries_countintЖелаемое количество элементов.
use_image_paletteboolЕсли установлено, будет использована собственная палитра изображения, если она доступна

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_close_image_palette(image, dest_bounds, entries_count, use_image_palette, alpha_blend_in_color) [static]

 get_close_image_palette(image, dest_bounds, entries_count, use_image_palette, alpha_blend_in_color) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
dest_boundsRectangleГраницы целевого изображения.
entries_countintЖелаемое количество элементов.
use_image_paletteboolЕсли установлено, будет использована собственная палитра изображения, если она доступна
alpha_blend_in_colorColorЦвет, который следует использовать в качестве фонового при полупрозрачной замене альфа‑канала.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_close_image_palette(image, dest_bounds, entries_count, use_image_palette, alpha_blend_in_color, keep_transparency) [static]

 get_close_image_palette(image, dest_bounds, entries_count, use_image_palette, alpha_blend_in_color, keep_transparency) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
dest_boundsRectangleГраницы целевого изображения.
entries_countintЖелаемое количество элементов.
use_image_paletteboolЕсли установлено, будет использована собственная палитра изображения, если она доступна
alpha_blend_in_colorColorЦвет, который следует использовать в качестве фонового при полупрозрачной замене альфа‑канала.
keep_transparencyboolЕсли установлено, будут учитываться биты альфа‑канала цветов изображения.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_close_image_palette(image, entries_count) [static]

 get_close_image_palette(image, entries_count) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
entries_countintЖелаемое количество элементов.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

See also:

Example # 1: The following example shows how to set a palette to a BMP image to reduce its…

Example # 2: The following example loads a BMP image and saves it back to BMP using variou…

Method: get_close_image_palette(image, entries_count, palette_mining_method) [static]

 get_close_image_palette(image, entries_count, palette_mining_method) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Палитра будет оптимизирована для лучшего качества индексированного изображения или оставлена “AS IS”, когда используется PaletteMiningMethod.UseCurrentPalette.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
entries_countintЖелаемое количество элементов.
palette_mining_methodPaletteMiningMethodМетод извлечения палитры.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

See also:

Example # 1: The following example shows how to compress a PNG image, using indexed color …

Method: get_close_image_palette_by_method(image, entries_count, palette_mining_method) [static]

 get_close_image_palette_by_method(image, entries_count, palette_mining_method) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Палитра будет оптимизирована для лучшего качества индексированного изображения или оставлена “AS IS”, когда используется PaletteMiningMethod.UseCurrentPalette.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
entries_countintЖелаемое количество элементов.
palette_mining_methodPaletteMiningMethodМетод извлечения палитры.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_close_image_palette_by_rect(image, dest_bounds, entries_count) [static]

 get_close_image_palette_by_rect(image, dest_bounds, entries_count) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
dest_boundsRectangleГраницы целевого изображения.
entries_countintЖелаемое количество элементов.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_close_transparent_image_palette(image, entries_count) [static]

 get_close_transparent_image_palette(image, entries_count) 

Получает цветовую палитру из растрового изображения (палетизирует изображение), если у изображения её нет. Если палитра существует, она будет использована вместо выполнения вычислений.

Parameters:

ПараметрТипОписание
imageRasterImageРастровое изображение.
entries_countintЖелаемое количество элементов.

Returns

ТипОписание
IColorPaletteЦветовая палитра, которая начинается с самых часто встречающихся цветов из image и содержит entriesCount элементов.

Method: get_downscale_palette(image) [static]

 get_downscale_palette(image) 

Получить 256‑цветную палитру, составленную из старших битов начальных цветовых значений изображения.

Parameters:

ПараметрТипОписание
imageRasterImageИзображение.

Returns

ТипОписание
ColorPaletteКласс ColorPalette.

Method: get_uniform_color_palette(image) [static]

 get_uniform_color_palette(image) 

Получить однородную 256‑цветную палитру.

Parameters:

ПараметрТипОписание
imageRasterImageИзображение.

Returns

ТипОписание
ColorPaletteКласс ColorPalette.

Method: has_transparent_colors(palette) [static]

 has_transparent_colors(palette) 

Определяет, содержит ли указанная палитра прозрачные цвета.

Parameters:

ПараметрТипОписание
paletteIColorPaletteПалитра.

Returns

ТипОписание
booltrue если указанная палитра содержит прозрачные цвета; в противном случае false.

Examples

The following example shows how to set a palette to a BMP image to reduce its output size.


from aspose.pycore import as_of
from aspose.imaging import Point, Color, Graphics, ColorPaletteHelper
from aspose.imaging.brushes import LinearGradientBrush
from aspose.imaging.fileformats.bmp import BmpImage
from aspose.imaging.imageoptions import BmpOptions
from os.path import join as path_join

# Создайте BMP‑изображение размером 100 × 100 px.
with BmpImage(100, 100) as bmpImage:
	# Линейный градиент от левого верхнего до правого нижнего угла изображения.
	brush = LinearGradientBrush(Point(0, 0), Point(bmpImage.width, bmpImage.height),
								Color.red,
								Color.green)
	# Заполните всё изображение кистью линейного градиента.
	gr = Graphics(bmpImage)
	gr.fill_rectangle(brush, bmpImage.bounds)
	# Получите ближайшую 8‑битную цветовую палитру, покрывающую как можно больше пикселей, так чтобы палитризированное изображение
	# было почти визуально неотличимо от BMP без палитры
	palette = ColorPaletteHelper.get_close_image_palette(bmpImage, 256)
	# 8‑битная палитра содержит не более 256 цветов.
	saveOptions = BmpOptions()
	saveOptions.palette = palette
	saveOptions.bits_per_pixel = 8
	
	with stream_ext.create_memory_stream() as stream:
		bmpImage.save(stream, saveOptions)
		print(f"The size of image with palette is {stream.tell()} bytes.")
		stream.seek(0)
		bmpImage.save(stream)
		print(f"The size of image without palette is {stream.tell()} bytes.")

# Вывод выглядит так:
# Размер изображения с палитрой составляет 11078 байт.
# Размер изображения без палитры составляет 40054 байт.

The following example shows how to compress a PNG image, using indexed color with best fit palette


from aspose.pycore import as_of
from aspose.imaging import Image, ColorPaletteHelper, RasterImage, PaletteMiningMethod
from aspose.imaging.fileformats.png import PngColorType

# Загружает PNG‑изображение
sourceFilePath = "OriginalRings.png"
outputFilePath = "OriginalRingsOutput.png"
with Image.load(sourceFilePath) as image:
	png_options = PngOptions()
	png_options.progressive = True
	# Использовать индексный тип цвета
	png_options.color_type = PngColorType.INDEXED_COLOR
	# Использовать максимальное сжатие
	png_options.compression_level = 9
	# Получите ближайшую 8‑битную цветовую палитру, покрывающую как можно больше пикселей, так чтобы изображение
	# с палитрой было почти визуально неотличимо от изображения без палитры.
	png_options.palette = ColorPaletteHelper.get_close_image_palette(
						as_of(image, RasterImage), 256, 
						PaletteMiningMethod.HISTOGRAM)
		 
	image.save(outputFilePath, png_options);
}
# Размер выходного файла должен значительно уменьшиться

The following example loads a BMP image and saves it back to BMP using various save options.

from aspose.imaging import Image, RasterImage, ColorPaletteHelper, ResolutionSetting
from aspose.imaging.imageoptions import BmpOptions
from aspose.imaging.fileformats.bmp import BitmapCompression
import os
import aspose.pycore as aspycore

directory = "c:\\temp\\"

with Image.load(os.path.join(directory, "sample.bmp")) as image:
	
	rasterImage = aspycore.as_of(image, RasterImage)

	# Создайте BmpOptions
	saveOptions = BmpOptions()

	# Используйте 8 бит на пиксель, чтобы уменьшить размер выходного изображения.
	saveOptions.bits_per_pixel = 8

	# Установите ближайшую 8‑битную цветовую палитру, покрывающую максимальное количество пикселей изображения, так чтобы палитризированное изображение
	# почти визуально не отличим от непалетизированного.
	saveOptions.palette = ColorPaletteHelper.get_close_image_palette(rasterImage, 256)

	# Сохранить без сжатия.
	# Вы также можете использовать сжатие RLE-8, чтобы уменьшить размер выходного изображения.
	saveOptions.compression = BitmapCompression.RGB

	# Установите горизонтальное и вертикальное разрешение в 96 dpi.
	saveOptions.resolution_settings = ResolutionSetting(96.0, 96.0)

	image.save(os.path.join(directory, "sample.bmpoptions.bmp"), saveOptions)