python渐变色代码_如何在Python中创建颜色渐变?
6 個(gè)答案:
答案 0 :(得分:54)
我還沒有看到一個(gè)簡(jiǎn)單的答案就是使用colour package。
通過(guò)pip安裝
pip install colour
如此使用:
from colour import Color
red = Color("red")
colors = list(red.range_to(Color("green"),10))
# colors is now a list of length 10
# Containing:
# [, , , , , , , , , ]
將輸入更改為您想要的任何顏色
答案 1 :(得分:26)
很明顯,您的原始示例漸變不是線性的。查看圖像中平均紅色,綠色和藍(lán)色值的圖表:
嘗試使用線性漸變的組合來(lái)重新創(chuàng)建它將是困難的。
對(duì)我來(lái)說(shuō),每種顏色看起來(lái)都像是兩條高斯曲線的加法,所以我做了一些最佳配合,并提出了這個(gè):
使用這些計(jì)算出的值,我可以創(chuàng)建一個(gè)非常漂亮的漸變,幾乎完全匹配你的。
import math
from PIL import Image
im = Image.new('RGB', (604, 62))
ld = im.load()
def gaussian(x, a, b, c, d=0):
return a * math.exp(-(x - b)**2 / (2 * c**2)) + d
for x in range(im.size[0]):
r = int(gaussian(x, 158.8242, 201, 87.0739) + gaussian(x, 158.8242, 402, 87.0739))
g = int(gaussian(x, 129.9851, 157.7571, 108.0298) + gaussian(x, 200.6831, 399.4535, 143.6828))
b = int(gaussian(x, 231.3135, 206.4774, 201.5447) + gaussian(x, 17.1017, 395.8819, 39.3148))
for y in range(im.size[1]):
ld[x, y] = (r, g, b)
不幸的是,我還不知道如何將其推廣為任意顏色。
答案 2 :(得分:6)
如果你只需要插入2種顏色,我就為此編寫了一個(gè)簡(jiǎn)單的函數(shù)。 colorFader使用其他兩個(gè)十六進(jìn)制顏色代碼創(chuàng)建一個(gè)十六進(jìn)制顏色代碼。
import matplotlib as mpl
import matplotlib.pyplot as plt
import numpy as np
def colorFader(c1,c2,mix=0): #fade (linear interpolate) from color c1 (at mix=0) to c2 (mix=1)
c1=np.array(mpl.colors.to_rgb(c1))
c2=np.array(mpl.colors.to_rgb(c2))
return mpl.colors.to_hex((1-mix)*c1 + mix*c2)
c1='#1f77b4' #blue
c2='green' #green
n=500
fig, ax = plt.subplots(figsize=(8, 5))
for x in range(n+1):
ax.axvline(x, color=colorFader(c1,c2,x/n), linewidth=4)
plt.show()
結(jié)果:強(qiáng)>
由于高興趣而更新:
colorFader現(xiàn)在適用于rgb-colors和顏色字符串,如“red”或“r”。
答案 3 :(得分:6)
每個(gè)元組的第一個(gè)元素(0,0.25,0.5等)是顏色應(yīng)該是某個(gè)值的位置。我拿了5個(gè)樣本來(lái)查看RGB組件(在GIMP中),并將它們放在表格中。 RGB分量從0變?yōu)?,因此我必須將它們除以255.0以縮放正常的0-255值。
5分是一個(gè)相當(dāng)粗略的近似值 - 如果你想要一個(gè)更平滑的'外觀,使用更多的價(jià)值觀。
from matplotlib import pyplot as plt
import matplotlib
import numpy as np
plt.figure()
a=np.outer(np.arange(0,1,0.01),np.ones(10))
fact = 1.0/255.0
cdict2 = {'red': [(0.0, 22*fact, 22*fact),
(0.25, 133*fact, 133*fact),
(0.5, 191*fact, 191*fact),
(0.75, 151*fact, 151*fact),
(1.0, 25*fact, 25*fact)],
'green': [(0.0, 65*fact, 65*fact),
(0.25, 182*fact, 182*fact),
(0.5, 217*fact, 217*fact),
(0.75, 203*fact, 203*fact),
(1.0, 88*fact, 88*fact)],
'blue': [(0.0, 153*fact, 153*fact),
(0.25, 222*fact, 222*fact),
(0.5, 214*fact, 214*fact),
(0.75, 143*fact, 143*fact),
(1.0, 40*fact, 40*fact)]}
my_cmap2 = matplotlib.colors.LinearSegmentedColormap('my_colormap2',cdict2,256)
plt.imshow(a,aspect='auto', cmap =my_cmap2)
plt.show()
請(qǐng)注意,紅色很明顯。它就在那里因?yàn)橹行膮^(qū)域接近灰色 - 這三個(gè)組成部分是必要的。
這會(huì)產(chǎn)生:
答案 4 :(得分:5)
這會(huì)創(chuàng)建一個(gè)由單個(gè)參數(shù)y:控制的色彩映射
from matplotlib.colors import LinearSegmentedColormap
def bluegreen(y):
red = [(0.0, 0.0, 0.0), (0.5, y, y), (1.0, 0.0, 0.0)]
green = [(0.0, 0.0, 0.0), (0.5, y, y), (1.0, y, y)]
blue = [(0.0, y, y), (0.5, y, y),(1.0,0.0,0.0)]
colordict = dict(red=red, green=green, blue=blue)
bluegreenmap = LinearSegmentedColormap('bluegreen', colordict, 256)
return bluegreenmap
red從0上升到y(tǒng),然后回到0. green從0上升到y(tǒng)然后是常量。 blue的{??{1}}星在y處出現(xiàn),并且在上半場(chǎng)保持不變,然后降至0。
這里是y = 0.7:的情節(jié)
您可以使用添加另一個(gè)或兩個(gè)段來(lái)平滑它。
答案 5 :(得分:4)
我也需要這個(gè),但我想輸入多個(gè)任意顏色點(diǎn)。考慮一個(gè)熱圖,你需要黑色,藍(lán)色,綠色...一直到#34;熱"顏色。我借用了Mark Ransom上面的代碼并將其擴(kuò)展以滿足我的需求。我很滿意。我要感謝所有人,尤其是馬克。
此代碼與圖像大小無(wú)關(guān)(高斯分布中沒有常數(shù));您可以使用width =參數(shù)將其更改為pixel()。它還允許調(diào)整"傳播" ( - > stddev)的分布;你可以通過(guò)將spread =參數(shù)更改為pixel()來(lái)進(jìn)一步混淆它們或引入黑帶。
#!/usr/bin/env python
import math
from PIL import Image
im = Image.new('RGB', (3000, 2000))
ld = im.load()
# A map of rgb points in your distribution
# [distance, (r, g, b)]
# distance is percentage from left edge
heatmap = [
[0.0, (0, 0, 0)],
[0.20, (0, 0, .5)],
[0.40, (0, .5, 0)],
[0.60, (.5, 0, 0)],
[0.80, (.75, .75, 0)],
[0.90, (1.0, .75, 0)],
[1.00, (1.0, 1.0, 1.0)],
]
def gaussian(x, a, b, c, d=0):
return a * math.exp(-(x - b)**2 / (2 * c**2)) + d
def pixel(x, width=100, map=[], spread=1):
width = float(width)
r = sum([gaussian(x, p[1][0], p[0] * width, width/(spread*len(map))) for p in map])
g = sum([gaussian(x, p[1][1], p[0] * width, width/(spread*len(map))) for p in map])
b = sum([gaussian(x, p[1][2], p[0] * width, width/(spread*len(map))) for p in map])
return min(1.0, r), min(1.0, g), min(1.0, b)
for x in range(im.size[0]):
r, g, b = pixel(x, width=3000, map=heatmap)
r, g, b = [int(256*v) for v in (r, g, b)]
for y in range(im.size[1]):
ld[x, y] = r, g, b
im.save('grad.png')
總結(jié)
以上是生活随笔為你收集整理的python渐变色代码_如何在Python中创建颜色渐变?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python中math库_Python的
- 下一篇: DIY自己装机必备,凯侠RC10硬盘,让