from builtins import super
import math
from ..tecutil import _tecutil
from ..constant import *
from ..exception import *
from .. import constant, session, tecutil, version
from ..tecutil import RectTuple, XYZPosition, lock, lock_attributes, sv
class _ViewActionsWithConsiderBlanking(object):
def fit_to_nice(self, consider_blanking=True):
"""Set axis range to begin/end on major axis increments.
Changes the view to make the extents of the frame neatly hold the
plot with integer values for axis labels.
Parameters:
consider_blanking (`Boolean <bool>`, optional): If `True` and
blanking is enabled, the resulting view excludes blanked cells
at the edges of the plot. If 'False`, then
the resulting view will ignore blanked cells at the edges of the
plot. (default: `True`)
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.NiceFit, consider_blanking)
def fit(self, consider_blanking=True):
"""Fit the data being plotted within the axis grid area.
.. note:: This also takes into consideration text and geometries that
are plotted using the grid coordinate system.
Parameters:
consider_blanking (`Boolean <bool>`, optional): If `True` and
blanking is enabled, the resulting view excludes blanked cells
at the edges of the plot. If 'False`, then
the resulting view will ignore blanked cells at the edges of the
plot. (default: `True`)
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.Fit, consider_blanking)
def fit_data(self, consider_blanking=True):
"""Fit data zones or line mappings within the grid area.
Parameters:
consider_blanking (`Boolean <bool>`, optional): If `True` and
blanking is enabled, the resulting view excludes blanked cells
at the edges of the plot. If 'False`, then
the resulting view will ignore blanked cells at the edges of the
plot. (default: `True`)
.. note:: This does not take into consideration text and geometries that
are plotted using the grid coordinate system.
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.DataFit, consider_blanking)
def center(self, consider_blanking=True):
"""Center the data within the axis grid area.
Parameters:
consider_blanking (`Boolean <bool>`, optional): If `True` and
blanking is enabled, the resulting view excludes blanked cells
at the edges of the plot. If 'False`, then
the resulting view will ignore blanked cells at the edges of the
plot. (default: `True`)
Raises:
`TecplotSystemError`: View could not be centered.
"""
self._view_action(constant.View.Center, consider_blanking)
class _ViewActionsWithoutConsiderBlanking(object):
def fit_to_nice(self):
"""Set axis range to begin/end on major axis increments.
Changes the view to make the extents of the frame neatly hold the
plot with integer values for axis labels.
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.NiceFit)
def fit(self):
"""Fit the data being plotted within the axis grid area.
.. note:: This also takes into consideration text and geometries that
are plotted using the grid coordinate system.
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.Fit)
def fit_data(self):
"""Fit data zones or line mappings within the grid area.
.. note:: This does not take into consideration text and geometries that
are plotted using the grid coordinate system.
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.DataFit)
def center(self):
"""Center the data within the axis grid area.
Raises:
`TecplotSystemError`: View could not be centered.
"""
self._view_action(constant.View.Center)
class _CommonViewActions(object):
""""Mix-in class so that we don't have to duplicate code or documentation
for view action functions available to all view types.
This mix-in class contains methods that should be available to all view
classes (3D, 2D, XY, Polar).
"""
@property
def magnification(self):
"""Magnification for the data being plotted.
:type: `float`
The ``magnification`` value is a decimal percent and must
be greater than 0. A ``magnification`` size of 1.0 (100%)
will size the plot so that it can fit within the grid area.
Raises:
`TecplotSystemError`: Magnification could not be queried or set.
Possible cases where `TecplotSystemError` is raised include
XY plots where no mappings are active or floating point
out of range error
Scale the view to ten percent of the size at which the
data would fit the full frame::
>>> view.magnification = 0.10
>>> view.magnification
0.10
"""
bool_result, result = _tecutil.ViewGetMagnification()
if not bool_result:
raise TecplotSystemError()
return result
@magnification.setter
def magnification(self, value):
with lock():
if not _tecutil.ViewSetMagnification(float(value)):
raise TecplotSystemError()
@lock()
def translate(self, x=0.0, y=0.0):
"""Shift the data being plotted in the X and/or Y direction.
.. note:: The amount translated is in frame units.
Parameters:
x (`float`, optional): Amount to shift in the X direction
as a percentage of the frame width. Positive values shift right,
negative values shift left. (default: 0.0)
y (`float`, optional): Amount to shift in the Y direction
as a percentage of the frame height. Positive values shift up,
negative values shift down. (default: 0.0)
Raises:
`TecplotSystemError`: View could not be translated.
Translate the view 10 percent of the frame width to the right::
>>> view.translate(x=10)
Translate the view 5 percent of the frame width to the right,
20 of the frame height down::
>>> view.translate(x=5, y=-20)
"""
with self.plot.frame.activated():
if not _tecutil.ViewTranslate(float(x),
float(y)):
raise TecplotSystemError()
class _XYOr2DOnlyViewActions(object):
"""Mix-in class so that we don't have to duplicate code or doc
for view action functions available to 2D and XY view types.
This mix-in class contains methods which should be available
in non-Polar 2D view classes (XY or 2D).
"""
@lock()
def zoom(self, xmin, xmax, ymin, ymax):
"""Zoom the view to a rectangular region of the plot.
Change the view by "zooming" into the data. Ranges on the axes are
adjusted to view the region defined by the rectangle with corners at
(``xmin``, ``ymin``) and (``xmax``, ``ymax``).
.. note:: All position values are defined in units of the X- and
Y- axis (that is, grid coordinates).
Parameters:
xmin: (`float`) X min corner of the rectangle to be viewed.
xmax: (`float`) X max corner of the rectangle to be viewed.
ymin: (`float`) Y min corner of the rectangle to be viewed.
ymax: (`float`) Y max corner of the rectangle to be viewed.
Raises:
`TecplotSystemError`: The view could not be zoomed.
Zoom so the rectangular region with corners at (xmin, ymin)=(1,0)
and (xmax, ymax)=(7,9) is in view::
>>> view.zoom(1, 7, 0, 9)
"""
with self.plot.frame.activated():
if not _tecutil.ViewZoom(
float(xmin), float(ymin), float(xmax), float(ymax)):
raise TecplotSystemError()
def adjust_to_nice(self):
"""Shifts axes to make axis-line values "nice"
Modifies the axis range to fit the minimum and maximum of the
variable assigned to that axis, then snaps the major tick marks to
the ends of the axis. If axis dependency is not independent,
this may affect the range on another axis.
In other words, given an existing range of values RMin, RMax and an
initial delta, D (such as axis ranges with grid spacing or
contour levels), determine a new delta (ND) that:
* Is 1,2, or 5 times 10 to some power that is the "best"
alternative to D.
* Produces new range min and max values that are some multiple of ND
that are nearest the original RMin and RMax
Axes are shifted without changing the extents of the window.
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.MakeCurrentViewNice)
@lock_attributes
class _View(object):
def __init__(self, plot):
self.plot = plot
@lock()
def _view_action(self, action, consider_blanking=None):
"""Internal implementation for all view actions which take a single
consider_blanking parameter."""
with self.plot.frame.activated():
with tecutil.ArgList() as arg_list:
arg_list[sv.VIEWOP] = action
if consider_blanking:
arg_list[sv.CONSIDERBLANKING] = True
if not _tecutil.ViewX(arg_list):
raise TecplotSystemError()
[docs]class Cartesian2DView(_View,
_ViewActionsWithConsiderBlanking,
_CommonViewActions,
_XYOr2DOnlyViewActions):
"""Adjust the way cartesian 2D data is displayed.
.. code-block:: python
:emphasize-lines: 16
from os import path
import tecplot as tp
from tecplot.constant import PlotType
examples_dir = tp.session.tecplot_examples_directory()
infile = path.join(examples_dir, 'SimpleData', 'HeatExchanger.plt')
dataset = tp.data.load_tecplot(infile)
frame = tp.active_frame()
plot = frame.plot(PlotType.Cartesian2D)
plot.activate()
plot.show_contour = True
plot.contour(0).variable = dataset.variable('P(N)')
plot.contour(0).colormap_name = 'Sequential - Yellow/Green/Blue'
plot.view.fit_to_nice()
tp.export.save_png('view_2D.png', 600, supersample=3)
.. figure:: /_static/images/view_2D.png
:width: 300px
:figwidth: 300px
"""
[docs]class Cartesian3DView(_View,
session.Style,
_CommonViewActions,
_ViewActionsWithConsiderBlanking):
"""Adjust the way cartesian 3D data is displayed.
.. code-block:: python
:emphasize-lines: 9-14
import tecplot
import os
from tecplot.constant import *
examples_dir = tecplot.session.tecplot_examples_directory()
infile = os.path.join(examples_dir, 'SimpleData', 'F18.plt')
ds = tecplot.data.load_tecplot(infile)
plot = tecplot.active_frame().plot(PlotType.Cartesian3D)
plot.activate()
plot.view.width = 17.5
plot.view.alpha = 0
plot.view.theta = 125
plot.view.psi = 65
plot.view.position = (-100, 80, 65)
tecplot.export.save_jpeg('view_3D.jpeg', 600, supersample=3)
.. figure:: /_static/images/view_3D.jpeg
:width: 300px
:figwidth: 300px
"""
def __init__(self, plot):
self.plot = plot
session.Style.__init__(self, sv.THREEDVIEW, uniqueid=plot.frame.uid)
[docs] @lock()
def zoom(self, xmin, xmax, ymin, ymax):
"""Zoom the view to a rectangular region of the plot.
Change the view by "zooming" into the data. Ranges on the axes are
adjusted to view the region defined by the rectangle with corners at
(``xmin``, ``ymin``) and (``xmax``, ``ymax``).
.. note:: All position values are defined in units of the X- and
Y- axis (that is, grid coordinates).
Parameters:
xmin: (`float`) X min corner of the rectangle to be viewed.
xmax: (`float`) X max corner of the rectangle to be viewed.
ymin: (`float`) Y min corner of the rectangle to be viewed.
ymax: (`float`) Y max corner of the rectangle to be viewed.
Raises:
`TecplotSystemError`: The view could not be zoomed.
Zoom so the rectangular region with corners at (xmin, ymin)=(1,0)
and (xmax, ymax)=(7,9) is in view::
>>> view.zoom(1, 7, 0, 9)
"""
with self.plot.frame.activated():
if not _tecutil.ViewZoom(
float(xmin), float(ymin), float(xmax), float(ymax)):
raise TecplotSystemError()
[docs] @lock()
def fit(self, consider_blanking=True):
"""Fit the data being plotted within the axis grid area.
.. note:: This also takes into consideration text and geometries that
are plotted using the grid coordinate system. Axes are also
included.
Parameters:
consider_blanking (`Boolean <bool>`, optional): If `True` and
blanking is enabled, the resulting view excludes blanked cells
at the edges of the plot. If 'False`, then
the resulting view will ignore blanked cells at the edges of the
plot. (default: `True`)
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.Fit, consider_blanking)
[docs] @lock()
def rotate_to_angles(self, psi, theta, alpha):
"""Rotate the plot to specific angles.
Parameters:
psi: (`float`): Tilt, in degrees, of the eye origin ray away from the Z-axis.
theta: (`float`): Rotation, in degrees, of the eye origin ray about the Z-axis.
alpha: (`float`): Twist, in degrees, about the eye origin ray.
"""
_tecutil.RotateToSpecificAngles(float(psi), float(theta), float(alpha))
[docs] def fit_surfaces(self, consider_blanking=True):
"""Fit 3D plot surfaces to the grid area.
Parameters:
consider_blanking (`Boolean <bool>`, optional): If `True` and
blanking is enabled, the resulting view excludes blanked cells
at the edges of the plot. If 'False`, then
the resulting view will ignore blanked cells at the edges of the
plot. (default: `True`)
.. note:: 3D volume zones are excluded when `surfaces_to_plot` is
`SurfacesToPlot.None_`.
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.FitSurfaces, consider_blanking)
@property
def _draw_in_perspective(self):
# DRAWINPERSPECTIVE is deprecated, but we use it privately for backward
# compatibility if PROJECTION is not available.
return self._get_style(bool, sv.DRAWINPERSPECTIVE)
@property
def field_of_view(self):
"""Amount of the plot which is displayed.
:type: `float`
Get or set the amount of the plot (in terms of spherical arc) in front
of the viewer that may be seen.
.. warning:: ``field_of_view`` cannot be set if `projection`
is `Projection.Orthographic`.
Example usage::
>>> from tecplot.constant import Projection
>>> plot.view.projection = Projection.Perspective
>>> plot.view.field_of_view = 9.6
"""
return self._get_style(float, sv.FIELDOFVIEW)
@field_of_view.setter
def field_of_view(self, value):
if __debug__:
if not self._draw_in_perspective:
raise TecplotValueError('Cannot set field_of_view if not '
'using perspective.')
self._set_style(float(value), sv.FIELDOFVIEW)
@staticmethod
def _check_projection_supported():
if __debug__:
sdk_version_required = (2017, 2, 0, 78708)
if version.sdk_version_info < sdk_version_required:
raise TecplotOutOfDateEngineError(
sdk_version_required,
'Cartesian3DView.projection() is not supported.')
@property
def projection(self):
"""Projection type (`Perspective` or `Orthographic`).
:type: `Projection`
When set to Perspective, Tecplot 360 draws the plot in perspective.
When set to Orthographic, the plot is drawn with orthographic
projection where the shape of the object does not change with distance.
.. note:: Requires Tecplot version 2017.2 or later.
Example usage::
>>> from tecplot.constant import Projection
>>> plot.view.projection = Projection.Orthographic
"""
self._check_projection_supported()
return self._get_style(Projection, sv.PROJECTION)
@projection.setter
def projection(self, value):
self._check_projection_supported()
self._set_style(Projection(value), sv.PROJECTION)
@property
def psi(self):
"""Eye origin view Psi angle in degrees.
The Psi angle is the tilt of the eye origin ray away from the Z-axis.
:type: `float`
Example usage::
>>> plot.view.psi = 90.0
"""
return self._get_style(float, sv.PSIANGLE)
@psi.setter
def psi(self, angle):
self._set_style(math.fmod(float(angle), 360.0), sv.PSIANGLE)
@property
def theta(self):
"""Eye origin view Theta angle in degrees.
The Theta angle is the rotation of the eye origin ray about the
Z-axis.
:type: `float`
Example usage::
>>> plot.view.theta = 24.3
"""
return self._get_style(float, sv.THETAANGLE)
@theta.setter
def theta(self, angle):
self._set_style(math.fmod(float(angle), 360.0), sv.THETAANGLE)
@property
def alpha(self):
"""Eye origin view Alpha angle in degrees.
The Alpha angle is the twist about the eye origin ray.
:type: `float`
Example usage::
>>> plot.view.alpha = 95.0
"""
return self._get_style(float, sv.ALPHAANGLE)
@alpha.setter
def alpha(self, angle):
self._set_style(math.fmod(float(angle), 360.0), sv.ALPHAANGLE)
@property
def position(self):
"""3D viewer position.
The viewer position is the viewer's relation to the image.
:type: 3-`tuple` of `floats <float>`
Example usage::
>>> plot.view.position
(1.25, 3.2, 0.74)
>>> plot.view.position.x
1.25
>>> plot.view.position = (2.5, 0.0, 1.0)
>>> plot.view.position.y
0.0
>>> plot.view.position.z
1.0
.. seealso:: `distance`
"""
return self._get_style(XYZPosition, sv.VIEWERPOSITION)
@position.setter
def position(self, pos):
self._set_style(XYZPosition(*pos), sv.VIEWERPOSITION)
@property
def width(self):
"""3D view width.
:type: `float`
The 3D view width is the amount of the plot (in X-axis units) in front
of the viewer that may be seen.
.. warning:: `width` cannot be set if `projection` is `Perspective`.
Example usage::
>>> plot.view.width = 1.5
"""
return self._get_style(float, sv.VIEWWIDTH)
@width.setter
def width(self, value):
if __debug__:
if self._draw_in_perspective:
raise TecplotValueError('view width cannot be set if drawing '
'in perspective.')
self._set_style(float(value), sv.VIEWWIDTH)
@property
def distance(self):
"""Get or set the view distance.
:type: `float`
The view distance is the distance from the viewer to the plane that is
parallel to the screen and passes through the 3-D rotation origin.
.. note:: Changing this value will also change the viewer `position`.
.. seealso:: `position`
Example usage::
>>> plot.view.distance
13.5
>>> plot.view.distance = 10.0
>>> plot.view.distance
10.0
"""
return _tecutil.ThreeDViewGetDistanceToRotateOriginPlane()
@distance.setter
@lock()
def distance(self, value):
if not _tecutil.Set3DEyeDistance(float(value)):
raise TecplotSystemError()
[docs]class LineView(_View,
_CommonViewActions,
_XYOr2DOnlyViewActions,
_ViewActionsWithoutConsiderBlanking):
"""Adjust the way XY Line data is displayed.
.. code-block:: python
:emphasize-lines: 20
import os
import tecplot
from tecplot.constant import *
examples_dir = tecplot.session.tecplot_examples_directory()
datafile = os.path.join(examples_dir, 'SimpleData', 'Rainfall.dat')
dataset = tecplot.data.load_tecplot(datafile)
frame = tecplot.active_frame()
plot = frame.plot()
frame.plot_type = tecplot.constant.PlotType.XYLine
for i in range(3):
plot.linemap(i).show = True
plot.linemap(i).line.line_thickness = .4
y_axis = plot.axes.y_axis(0)
y_axis.title.title_mode = AxisTitleMode.UseText
y_axis.title.text = 'Rainfall (in)'
plot.view.fit_to_nice()
tecplot.export.save_png('view_line.png', 600, supersample=3)
.. figure:: /_static/images/view_line.png
:width: 300px
:figwidth: 300px
"""
[docs]class PolarView(_View, session.Style,
_CommonViewActions,
_ViewActionsWithoutConsiderBlanking):
"""Adjust the way polar data is displayed.
.. code-block:: python
:emphasize-lines: 27-28
import numpy as np
import tecplot as tp
from tecplot.constant import PlotType, ThetaMode
frame = tp.active_frame()
npoints = 300
r = np.linspace(0, 2000, npoints)
theta = np.linspace(0, 10, npoints)
dataset = frame.create_dataset('Data', ['R', 'Theta'])
zone = dataset.add_ordered_zone('Zone', (300,))
zone.values('R')[:] = r
zone.values('Theta')[:] = theta
plot = frame.plot(PlotType.PolarLine)
plot.activate()
plot.axes.r_axis.max = np.max(r)
plot.axes.theta_axis.mode = ThetaMode.Radians
plot.delete_linemaps()
lmap = plot.add_linemap('Linemap', zone, dataset.variable('R'),
dataset.variable('Theta'))
lmap.line.line_thickness = 0.8
plot.view.reset_to_entire_circle()
plot.view.fit()
tp.export.save_png('view_polar.png', 600, supersample=3)
.. figure:: /_static/images/view_polar.png
:width: 300px
:figwidth: 300px
"""
def __init__(self, plot):
self.plot = plot
session.Style.__init__(self, sv.POLARVIEW, uniqueid=plot.frame.uid)
[docs] def reset_to_entire_circle(self):
"""Set the range of Theta to encompass an entire circle.
>>> plot.view.reset_to_entire_circle()
Raises:
`TecplotSystemError`: Internal error.
"""
self._view_action(constant.View.AxisResetToEntireCircle)
@property
def extents(self):
"""View extents in grid units of transformed X & Y.
:type: 4-`tuple` of `float` (x1, y1, x2, y2)
* x1, y1: Upper left corner of the extents.
* x2, y2: Lower right corner of the extents.
Set the view of the polar plot to view the full extents of the plot area::
>>> plot.view.extents = (10, 10, 90, 90)
>>> plot.view.extents.x1
10.0
>>> plot.view.extents.y1
10.0
>>> plot.view.extents.x2
90.0
>>> plot.view.extents.y2
90.0
"""
return RectTuple(self._get_style(sv.EXTENTS, sv.X1),
self._get_style(sv.EXTENTS, sv.Y1),
self._get_style(sv.EXTENTS, sv.X2),
self._get_style(sv.EXTENTS, sv.Y2))
@extents.setter
def extents(self, value):
for index, sv_value in enumerate((sv.X1, sv.Y1, sv.X2, sv.Y2)):
self._set_style(float(value[index]), sv.EXTENTS, sv_value)
[docs]@lock_attributes
class ReadOnlyViewport(session.Style):
def __init__(self, axes):
kw = dict(uniqueid=axes.plot.frame.uid)
super().__init__(*axes._sv, **kw)
@property
def bottom(self):
"""(`float`) Bottom position of viewport relative to the `Frame`.
:type: `float` in percentage of frame height from the bottom of the
frame.
Example usage::
>>> print(plot.axes.viewport.bottom)
10.0
"""
return self._get_style(float, sv.VIEWPORTPOSITION, sv.Y1)
@property
def left(self):
"""(`float`) Left position of viewport relative to the `Frame`.
:type: `float` in percentage of frame width from the left of the frame.
Example usage::
>>> print(plot.axes.viewport.left)
10.0
"""
return self._get_style(float, sv.VIEWPORTPOSITION, sv.X1)
@property
def right(self):
"""(`float`) Right position of viewport relative to the `Frame`.
:type: `float` in percentage of frame width from the left of the frame.
Example usage::
>>> print(plot.axes.viewport.right)
90.0
"""
return self._get_style(float, sv.VIEWPORTPOSITION, sv.X2)
@property
def top(self):
"""(`float`) Top position of viewport relative to the `Frame`.
:type: `float` in percentage of frame height from the bottom of the
frame.
Example usage::
>>> print(plot.axes.viewport.top)
90.0
"""
return self._get_style(float, sv.VIEWPORTPOSITION, sv.Y2)
[docs]class Viewport(ReadOnlyViewport):
bottom = ReadOnlyViewport.bottom
left = ReadOnlyViewport.left
right = ReadOnlyViewport.right
top = ReadOnlyViewport.top
@bottom.setter
def bottom(self, value):
self._set_style(float(value), sv.VIEWPORTPOSITION, sv.Y1)
@left.setter
def left(self, value):
self._set_style(float(value), sv.VIEWPORTPOSITION, sv.X1)
@right.setter
def right(self, value):
self._set_style(float(value), sv.VIEWPORTPOSITION, sv.X2)
@top.setter
def top(self, value):
self._set_style(float(value), sv.VIEWPORTPOSITION, sv.Y2)
[docs]class Cartesian2DViewport(Viewport):
@property
def nice_fit_buffer(self):
"""Tolerance for viewport/frame fit niceness.
:type: `float`
Example usage::
>>> plot.axes.viewport.nice_fit_buffer = 20
"""
return self._get_style(float, sv.VIEWPORTNICEFITBUFFER)
@nice_fit_buffer.setter
def nice_fit_buffer(self, value):
self._set_style(float(value), sv.VIEWPORTNICEFITBUFFER)
@property
def top_snap_target(self):
"""Target value for top when being adjusted or dragged.
:type: `float`
Example usage::
>>> plot.axes.viewport.top_snap_target = 90
"""
return self._get_style(float, sv.VIEWPORTTOPSNAPTARGET)
@top_snap_target.setter
def top_snap_target(self, value):
self._set_style(float(value), sv.VIEWPORTTOPSNAPTARGET)
@property
def top_snap_tolerance(self):
"""Tolerance for snapping to target value for top.
:type: `float`
Example usage::
>>> plot.axes.viewport.top_snap_tolerance = 8
"""
return self._get_style(float, sv.VIEWPORTTOPSNAPTOLERANCE)
@top_snap_tolerance.setter
def top_snap_tolerance(self, value):
self._set_style(float(value), sv.VIEWPORTTOPSNAPTOLERANCE)
[docs]class PolarViewport(Viewport):
@property
def fill_color(self):
if self._get_style(bool, sv.VIEWPORTSTYLE, sv.ISFILLED):
return self._get_style(Color, sv.VIEWPORTSTYLE, sv.FILLCOLOR)
@fill_color.setter
def fill_color(self, value):
if value is None:
self._set_style(False, sv.VIEWPORTSTYLE, sv.ISFILLED)
else:
self._set_style(True, sv.VIEWPORTSTYLE, sv.ISFILLED)
self._set_style(Color(value), sv.VIEWPORTSTYLE, sv.FILLCOLOR)
@property
def show_border(self):
return self._get_style(bool, sv.VIEWPORTSTYLE, sv.DRAWBORDER)
@show_border.setter
def show_border(self, value):
self._set_style(bool(value), sv.VIEWPORTSTYLE, sv.DRAWBORDER)
@property
def border_thickness(self):
return self._get_style(float, sv.VIEWPORTSTYLE, sv.LINETHICKNESS)
@border_thickness.setter
def border_thickness(self, value):
self._set_style(float(value), sv.VIEWPORTSTYLE, sv.LINETHICKNESS)
@property
def border_color(self):
return self._get_style(Color, sv.VIEWPORTSTYLE, sv.COLOR)
@border_color.setter
def border_color(self, value):
self._set_style(Color(value), sv.VIEWPORTSTYLE, sv.COLOR)