RGB Int в RGB - Python
Как преобразовать целое число RGB в соответствующий RGB кортеж (R,G,B)
? Кажется достаточно простым, но я ничего не могу найти в Google.
Я знаю, что для каждого RGB (R,G,B)
у вас есть целое число n = r256^2 + g256 + b
, как я могу решить обратное в Python, IE с учетом n
, мне нужны r
, g
, b
значения.
Ответы
Ответ 1
Я вообще не эксперт Python, но насколько я знаю, он имеет те же операторы, что и C.
Если это так, это должно работать, и это также должно быть намного быстрее, чем использование модулей и разделов.
Blue = RGBint & 255
Green = (RGBint >> 8) & 255
Red = (RGBint >> 16) & 255
Что он делает, чтобы маскировать младший байт в каждом случае (двоичный и с 255.. равно 8 бит). Для зеленого и красного компонентов он делает то же самое, но сначала переключает цветной канал на младший байт.
Ответ 2
Из целого числа RGB:
Blue = RGBint mod 256
Green = RGBint / 256 mod 256
Red = RGBint / 256 / 256 mod 256
Это может быть довольно просто реализовано, как только вы знаете, как его получить.:)
Обновление: добавлена функция python. Не уверен, есть ли лучший способ сделать это, но это работает на Python 3 и 2.4
def rgb_int2tuple(rgbint):
return (rgbint // 256 // 256 % 256, rgbint // 256 % 256, rgbint % 256)
Там также отличное решение, которое использует битхиттинг и маскировку, что, несомненно, намного быстрее, чем опубликовал Нильс Пипренбринк.
Ответ 3
>>> import struct
>>> str='aabbcc'
>>> struct.unpack('BBB',str.decode('hex'))
(170, 187, 204)
for python3:
>>> struct.unpack('BBB', bytes.fromhex(str))
и
>>> rgb = (50,100,150)
>>> struct.pack('BBB',*rgb).encode('hex')
'326496'
for python3:
>>> bytes.hex(struct.pack('BBB',*rgb))
Ответ 4
Я предполагаю, что у вас есть 32-разрядное целое число, содержащее значения RGB (например, ARGB). Затем вы можете распаковать двоичные данные с помощью модуля struct
:
# Create an example value (this represents your 32-bit input integer in this example).
# The following line results in exampleRgbValue = binary 0x00FF77F0 (big endian)
exampleRgbValue = struct.pack(">I", 0x00FF77F0)
# Unpack the value (result is: a = 0, r = 255, g = 119, b = 240)
a, r, g, b = struct.unpack("BBBB", exampleRgbValue)
Ответ 5
>>> r, g, b = (111, 121, 131)
>>> packed = int('%02x%02x%02x' % (r, g, b), 16)
В результате получается следующее целое число:
>>> packed
7305603
Затем вы можете распаковать его либо длинным явным способом:
>>> packed % 256
255
>>> (packed / 256) % 256
131
>>> (packed / 256 / 256) % 256
121
>>> (packed / 256 / 256 / 256) % 256
111
.. или более компактным образом:
>>> b, g, r = [(packed >> (8*i)) & 255 for i in range(3)]
>>> r, g, b
Образец применяется с любым количеством цифр, например, цветом RGBA:
>>> packed = int('%02x%02x%02x%02x' % (111, 121, 131, 141), 16)
>>> [(packed >> (8*i)) & 255 for i in range(4)]
[141, 131, 121, 111]
Ответ 6
Просто примечание для тех, кто использует API приложений Google Appengine Images Python. Я обнаружил, что у меня была ситуация, когда мне приходилось подавать метод с 32-битным значением цвета RGB.
В частности, если вы используете API для преобразования PNG (или любого изображения с прозрачными пикселями), вам необходимо предоставить метод execute_transforms аргументу с именем transparent_substitution_rgb, который должен быть 32-битным значением цвета RGB.
Заимствование из ответа dbr, я придумал метод, подобный этому:
def RGBTo32bitInt(r, g, b):
return int('%02x%02x%02x' % (r, g, b), 16)
transformed_image = image.execute_transforms(output_encoding=images.JPEG, transparent_substitution_rgb=RGBTo32bitInt(255, 127, 0))
Ответ 7
def unpack2rgb(intcol):
tmp, blue= divmod(intcol, 256)
tmp, green= divmod(tmp, 256)
alpha, red= divmod(tmp, 256)
return alpha, red, green, blue
Если было принято только предложение divmod(value, (divider1, divider2, divider3…))
, оно также упростило бы различные преобразования времени.
Ответ 8
Вероятно, более короткий способ сделать это:
dec=10490586
hex="%06x" % dec
r=hex[:2]
g=hex[2:4]
b=hex[4:6]
rgb=(r,g,b)
РЕДАКТИРОВАТЬ: это неправильно - дает ответ в Hex, OP хочет int.
EDIT2: усовершенствованный, чтобы уменьшить несчастье и неудачу - необходимо "% 06x", чтобы шестнадцатеричный символ всегда показывался как шесть цифр [спасибо комментарию Питера Хансена].
Ответ 9
Если вы используете NumPy, и у вас есть массив RGBints, вы также можете просто изменить его dtype, чтобы извлечь красные, зеленые, синие и альфа-компоненты:
>>> type(rgbints)
numpy.ndarray
>>> rgbints.shape
(1024L, 768L)
>>> rgbints.dtype
dtype('int32')
>>> rgbints.dtype = dtype('4uint8')
>>> rgbints.shape
(1024L, 768L, 4L)
>>> rgbints.dtype
dtype('uint8')
Ответ 10
Добавление к тому, что упоминалось выше. Краткая альтернатива с одним лайнером.
# 2003199 or #E190FF is Dodger Blue.
tuple((2003199 >> Val) & 255 for Val in (16, 8, 0))
# (30, 144, 255)
И во избежание путаницы в будущем.
from collections import namedtuple
RGB = namedtuple('RGB', ('Red', 'Green', 'Blue'))
rgb_integer = 16766720 # Or #ffd700 is Gold.
# The unpacking asterisk prevents a TypeError caused by missing arguments.
RGB(*((rgb_integer >> Val) & 255 for Val in (16, 8, 0)))
# RGB(Red=255, Green=215, Blue=0)