使用以下代码:
from matplotlib import pyplot as plt
from matplotlib_venn import venn2
from collections import OrderedDict
named_sets = {'x1': set(['foo','foo','bar',"pax"]), "x3" : set(['foo','qux','bar',"zoo"])}
od = OrderedDict(sorted(named_sets.iteritems()))
circlenm = ()
circlels = []
for k,v in od.iteritems():
circlenm = circlenm + (k,)
circlels.append(v)
c = venn2(subsets = circlels,set_labels = circlenm)
c.get_patch_by_id('10').set_color('red')
c.get_patch_by_id('01').set_color('blue')
c.get_patch_by_id('10').set_edgecolor('none')
c.get_patch_by_id('01').set_edgecolor('none')
c.get_patch_by_id('10').set_alpha(0.4)
c.get_patch_by_id('01').set_alpha(0.4)
plt.show()
我可以得到下图:
这里我想混合“蓝色”和“红色”的圆圈。注意混合的结果是棕色。
但实际值应该是浅洋红色(下图是使用默认matplotlib_venn.venn3
创建的):
我如何才能正确地做到这一点?
2条答案
按热度按时间6tqwzwtp1#
添加以下三条线以设置交点的颜色和显示特性:
如果你想要一个精确的颜色,那么你可以这样设置:
面片id是一个位掩码,显示该区域位于哪些圆内。
baubqpgj2#
当通过
set_colors
参数创建图表时,将颜色直接传递给venn2
,然后它将自动进行颜色混合: