mirror of
https://github.com/OpenFOAM/ThirdParty-6.git
synced 2025-12-08 06:57:43 +00:00
ParaView-5.0.1: Added the source-tree to ThirdParty-dev and patched as described in the README file
Resolves bug-report http://bugs.openfoam.org/view.php?id=2098
This commit is contained in:
143
ParaView-5.0.1/VTK/Examples/Annotation/Python/DispAllFonts.py
Executable file
143
ParaView-5.0.1/VTK/Examples/Annotation/Python/DispAllFonts.py
Executable file
@ -0,0 +1,143 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
# This example displays all possible combinations of font families and
|
||||
# styles. This example also shows how to create a simple Tkinter
|
||||
# based GUI for VTK-Python.
|
||||
|
||||
import vtk
|
||||
import sys
|
||||
if sys.hexversion < 0x03000000:
|
||||
# for Python2
|
||||
import Tkinter as tkinter
|
||||
else:
|
||||
# for Python3
|
||||
import tkinter
|
||||
from vtk.tk.vtkTkRenderWindowInteractor import \
|
||||
vtkTkRenderWindowInteractor
|
||||
import string
|
||||
|
||||
# We set the font size constraints, default text and colors
|
||||
current_font_size = 16
|
||||
min_font_size = 3
|
||||
max_font_size = 50
|
||||
|
||||
default_text = "ABCDEFGHIJKLMnopqrstuvwxyz(0123456789, !@#%()-=_+.:,./<>?"
|
||||
|
||||
# set default_text "The quick red fox"
|
||||
|
||||
text_color = [246/255.0, 255/255.0, 11/255.0]
|
||||
bg_color = [56/255.0, 56/255.0, 154/255.0]
|
||||
|
||||
# We create the render window which will show up on the screen
|
||||
# We put our renderer into the render window using AddRenderer.
|
||||
# Do not set the size of the window here.
|
||||
renWin = vtk.vtkRenderWindow()
|
||||
ren = vtk.vtkRenderer()
|
||||
ren.SetBackground(bg_color)
|
||||
renWin.AddRenderer(ren)
|
||||
|
||||
# We create text actors for each font family and several combinations
|
||||
# of bold, italic and shadowed style.
|
||||
text_actors = []
|
||||
for family in ("Arial", "Courier", "Times"):
|
||||
for (bold, italic, shadow) in ((0, 0, 0), (0, 0, 1), (1, 0, 0),
|
||||
(0, 1, 0), (1, 1, 0)):
|
||||
mapper = vtk.vtkTextMapper()
|
||||
attribs = []
|
||||
if bold:
|
||||
attribs.append("b")
|
||||
if italic:
|
||||
attribs.append("i")
|
||||
if shadow:
|
||||
attribs.append("s")
|
||||
|
||||
face_name = family
|
||||
if len(attribs):
|
||||
face_name = face_name + "(" + \
|
||||
",".join(attribs) + ")"
|
||||
|
||||
mapper.SetInput(face_name + ": " + default_text)
|
||||
tprop = mapper.GetTextProperty()
|
||||
eval("tprop.SetFontFamilyTo%s()"%family)
|
||||
tprop.SetColor(text_color)
|
||||
tprop.SetBold(bold)
|
||||
tprop.SetItalic(italic)
|
||||
tprop.SetShadow(shadow)
|
||||
|
||||
actor = vtk.vtkActor2D()
|
||||
actor.SetMapper(mapper)
|
||||
text_actors.append(actor)
|
||||
ren.AddActor(actor)
|
||||
|
||||
|
||||
# Now setup the tkinter GUI.
|
||||
|
||||
# Create the root window.
|
||||
root = tkinter.Tk()
|
||||
|
||||
# vtkTkRenderWindowInteractor is a Tk widget that we can render into.
|
||||
# It has a GetRenderWindow method that returns a vtkRenderWindow.
|
||||
# This can then be used to create a vtkRenderer and etc. We can also
|
||||
# specify a vtkRenderWindow to be used when creating the widget by
|
||||
# using the rw keyword argument, which is what we do here by using
|
||||
# renWin. It also takes width and height options that can be used to
|
||||
# specify the widget size, hence the render window size.
|
||||
vtkw = vtkTkRenderWindowInteractor(root, rw=renWin, width=800)
|
||||
|
||||
|
||||
# Once the VTK widget has been created it can be inserted into a whole
|
||||
# Tk GUI as well as any other standard Tk widgets.
|
||||
|
||||
# This function is called by the slider-widget handler whenever the
|
||||
# slider value changes (either through user interaction or
|
||||
# programmatically). It receives the slider value as parameter. We
|
||||
# update the corresponding VTK objects by calling the SetFontSize
|
||||
# method using this parameter and we render the scene to update the
|
||||
# pipeline.
|
||||
def set_font_size(sz):
|
||||
global text_actors, renWin
|
||||
size = int(sz)
|
||||
i = 0
|
||||
for actor in text_actors:
|
||||
i += 1
|
||||
actor.GetMapper().GetTextProperty().SetFontSize(size)
|
||||
actor.SetDisplayPosition(10, i*(size+5))
|
||||
|
||||
renWin.SetSize(800, 20+i*(size+5))
|
||||
renWin.Render()
|
||||
|
||||
# We create a size slider controlling the font size. The orientation
|
||||
# of this widget is horizontal (orient option). We label it using the
|
||||
# label option. Finally, we bind the scale to Python code by assigning
|
||||
# the command option to the name of a Python function. Whenever the
|
||||
# slider value changes this function will be called, enabling us to
|
||||
# propagate this GUI setting to the corresponding VTK object.
|
||||
size_slider = tkinter.Scale(root, from_=min_font_size,
|
||||
to=max_font_size, res=1,
|
||||
orient='horizontal', label="Font size:",
|
||||
command=set_font_size)
|
||||
size_slider.set(current_font_size)
|
||||
|
||||
# Finally we pack the VTK widget and the sliders on top of each other
|
||||
# (side='top') inside the main root widget.
|
||||
vtkw.Initialize()
|
||||
size_slider.pack(side="top", fill="both")
|
||||
vtkw.pack(side="top", fill='both', expand=1)
|
||||
|
||||
|
||||
# Define a quit method that exits cleanly.
|
||||
def quit(obj=root):
|
||||
obj.quit()
|
||||
|
||||
# We handle the WM_DELETE_WINDOW protocal request. This request is
|
||||
# triggered when the widget is closed using the standard window
|
||||
# manager icons or buttons. In this case the quit function will be
|
||||
# called and it will free up any objects we created then exit the
|
||||
# application.
|
||||
root.protocol("WM_DELETE_WINDOW", quit)
|
||||
|
||||
renWin.Render()
|
||||
vtkw.Start()
|
||||
|
||||
# start the tkinter event loop.
|
||||
root.mainloop()
|
||||
Reference in New Issue
Block a user