Introdução
Neste laboratório, demonstraremos como usar efeitos de filtragem com o gráfico de pizza do Matplotlib. Usaremos o código de desenho do gráfico de pizza emprestado de pie_demo.py e adicionaremos efeitos de filtragem ao gráfico. Os efeitos de filtragem são eficazes apenas se o seu renderizador SVG os suportar.
Dicas para a VM
Após a inicialização da VM, clique no canto superior esquerdo para mudar para a aba Notebook e acessar o Jupyter Notebook para praticar.
Às vezes, pode ser necessário aguardar alguns segundos para que o Jupyter Notebook termine de carregar. A validação das operações não pode ser automatizada devido a limitações no Jupyter Notebook.
Se você enfrentar problemas durante o aprendizado, sinta-se à vontade para perguntar ao Labby. Forneça feedback após a sessão, e resolveremos o problema prontamente para você.
Criar um Gráfico de Pizza
Criaremos uma figura e eixos quadrados para o nosso gráfico de pizza. Definiremos os rótulos e fracs para o gráfico. Também definiremos os valores de explode para as fatias do gráfico. Finalmente, desenharemos o gráfico de pizza com os parâmetros definidos.
import matplotlib.pyplot as plt
from matplotlib.patches import Shadow
fig = plt.figure(figsize=(6, 6))
ax = fig.add_axes([0.1, 0.1, 0.8, 0.8])
labels = 'Frogs', 'Hogs', 'Dogs', 'Logs'
fracs = [15, 30, 45, 10]
explode = (0, 0.05, 0, 0)
pies = ax.pie(fracs, explode=explode, labels=labels, autopct='%1.1f%%')
for w in pies[0]:
w.set_gid(w.get_label())
w.set_edgecolor("none")
for w in pies[0]:
s = Shadow(w, -0.01, -0.01)
s.set_gid(w.get_gid() + "_shadow")
s.set_zorder(w.get_zorder() - 0.1)
ax.add_patch(s)
plt.show()
Salvar o Gráfico como SVG
Salvaremos o gráfico de pizza como um arquivo SVG usando os módulos io e xml.etree.ElementTree. Definiremos a definição do filtro para a sombra usando um desfoque gaussiano e um efeito de iluminação. O filtro de iluminação é copiado de http://www.w3.org/TR/SVG/filters.html. Testaremos o filtro usando Inkscape e Firefox3, mas observe que a exportação do Inkscape pode não suportá-lo.
import io
import xml.etree.ElementTree as ET
f = io.BytesIO()
plt.savefig(f, format="svg")
filter_def = """
<defs xmlns='http://www.w3.org/2000/svg'
xmlns:xlink='http://www.w3.org/1999/xlink'>
<filter id='dropshadow' height='1.2' width='1.2'>
<feGaussianBlur result='blur' stdDeviation='2'/>
</filter>
<filter id='MyFilter' filterUnits='objectBoundingBox'
x='0' y='0' width='1' height='1'>
<feGaussianBlur in='SourceAlpha' stdDeviation='4%' result='blur'/>
<feOffset in='blur' dx='4%' dy='4%' result='offsetBlur'/>
<feSpecularLighting in='blur' surfaceScale='5' specularConstant='.75'
specularExponent='20' lighting-color='#bbbbbb' result='specOut'>
<fePointLight x='-5000%' y='-10000%' z='20000%'/>
</feSpecularLighting>
<feComposite in='specOut' in2='SourceAlpha'
operator='in' result='specOut'/>
<feComposite in='SourceGraphic' in2='specOut' operator='arithmetic'
k1='0' k2='1' k3='1' k4='0'/>
</filter>
</defs>
"""
tree, xmlid = ET.XMLID(f.getvalue())
tree.insert(0, ET.XML(filter_def))
for i, pie_name in enumerate(labels):
pie = xmlid[pie_name]
pie.set("filter", 'url(#MyFilter)')
shadow = xmlid[pie_name + "_shadow"]
shadow.set("filter", 'url(#dropshadow)')
fn = "svg_filter_pie.svg"
print(f"Saving '{fn}'")
ET.ElementTree(tree).write(fn)
Visualizar o Gráfico de Pizza com Efeitos de Filtragem
Visualizaremos o gráfico de pizza com os efeitos de filtragem aplicados. Usaremos o Inkscape para abrir o arquivo SVG e visualizar o gráfico de pizza com os efeitos de filtragem.
Modificar o Gráfico de Pizza com Diferentes Filtros
Podemos modificar o gráfico de pizza com diferentes filtros alterando a definição do filtro. Podemos experimentar com diferentes filtros para obter diferentes efeitos visuais.
filter_def = """
<defs xmlns='http://www.w3.org/2000/svg'
xmlns:xlink='http://www.w3.org/1999/xlink'>
<filter id='dropshadow' height='1.2' width='1.2'>
<feGaussianBlur result='blur' stdDeviation='2'/>
</filter>
<filter id='MyFilter2' filterUnits='objectBoundingBox'
x='0' y='0' width='1' height='1'>
<feGaussianBlur in='SourceAlpha' stdDeviation='4%' result='blur'/>
<feOffset in='blur' dx='4%' dy='4%' result='offsetBlur'/>
<feSpecularLighting in='blur' surfaceScale='5' specularConstant='.75'
specularExponent='20' lighting-color='#bbbbbb' result='specOut'>
<fePointLight x='50%' y='50%' z='5000%'/>
</feSpecularLighting>
<feComposite in='specOut' in2='SourceAlpha'
operator='in' result='specOut'/>
<feComposite in='SourceGraphic' in2='specOut' operator='arithmetic'
k1='0' k2='1' k3='1' k4='0'/>
</filter>
</defs>
"""
tree, xmlid = ET.XMLID(f.getvalue())
tree.insert(0, ET.XML(filter_def))
for i, pie_name in enumerate(labels):
pie = xmlid[pie_name]
pie.set("filter", 'url(#MyFilter2)')
shadow = xmlid[pie_name + "_shadow"]
shadow.set("filter", 'url(#dropshadow)')
fn = "svg_filter_pie2.svg"
print(f"Saving '{fn}'")
ET.ElementTree(tree).write(fn)
Resumo
Neste laboratório, aprendemos como usar efeitos de filtragem com o gráfico de pizza do Matplotlib. Criamos um gráfico de pizza, salvamos como um arquivo SVG e aplicamos efeitos de filtragem ao gráfico. Também modificamos o gráfico de pizza com diferentes filtros para obter diferentes efeitos visuais.