Viewer Properties
Viewer
properties control the appearance and behavior of a
Viewer
object. By changing property values, you can manage scene-level
controls for 2-D and 3-D image display. Create a Viewer
object configured for
2-D image display using the using the viewer2d
function. Create a Viewer
object configured for 3-D image display using the
viewer3d
function.
Use dot notation to query and set properties. For example, these commands show how to
create a Viewer
object, query the value of the
BackgroundColor
property, and set the value of the
BackgroundColor
property, respectively.
viewer = viewer3d; c = viewer.BackgroundColor; viewer.BackgroundColor = "blue";
Camera Controls
Camera position, or viewpoint, specified as a 3-element vector of the form
[x
y
z]. The camera is oriented along the view axis, which is a straight
line that connects the camera position and the camera target. Changing the
property changes the point
from which you view the image or volume. For an illustration, see Camera Graphics Terminology.CameraPosition
Camera target, specified as a 3-element vector of the form [x y z]. The camera is oriented along the view axis, which is a straight line that connects the camera position and the camera target. For an illustration, see Camera Graphics Terminology.
Upwards direction for the camera, specified as a 3-element vector of the form
[x
y
z]. By default, the z-axis is the up direction
([0 0 1]
). For an illustration, see Camera Graphics Terminology.
Camera zoom level, specified as a positive number.
Color
Color of the background, specified as an RGB triplet, a hexadecimal color code, a
color name, or a short color name. When you select light mode in MATLAB®, the default color is [0.9608 0.9608 0.9608]
if you
create the viewer using the viewer2d
function and [0 0.251 0.451]
if you create the viewer using the
viewer3d
function. When you select dark mode in MATLAB, the default color is [0.1 0.1 0.1]
, regardless of the
function you use to create the viewer.
For a custom color, specify an RGB triplet or a hexadecimal color code.
An RGB triplet is a three-element row vector whose elements specify the intensities of the red, green, and blue components of the color. The intensities must be in the range
[0,1]
, for example,[0.4 0.6 0.7]
.A hexadecimal color code is a string scalar or character vector that starts with a hash symbol (
#
) followed by three or six hexadecimal digits, which can range from0
toF
. The values are not case sensitive. Therefore, the color codes"#FF8800"
,"#ff8800"
,"#F80"
, and"#f80"
are equivalent.
Alternatively, you can specify some common colors by name. This table lists the named color options, the equivalent RGB triplets, and the hexadecimal color codes.
Color Name | Short Name | RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|---|---|
"red" | "r" | [1 0 0] | "#FF0000" | |
"green" | "g" | [0 1 0] | "#00FF00" | |
"blue" | "b" | [0 0 1] | "#0000FF" | |
"cyan"
| "c" | [0 1 1] | "#00FFFF" | |
"magenta" | "m" | [1 0 1] | "#FF00FF" | |
"yellow" | "y" | [1 1 0] | "#FFFF00" | |
"black" | "k" | [0 0 0] | "#000000" | |
"white" | "w" | [1 1 1] | "#FFFFFF" | |
"none" | Not applicable | Not applicable | Not applicable | No color |
This table lists the default color palettes for plots in the light and dark themes.
Palette | Palette Colors |
---|---|
Before R2025a: Most plots use these colors by default. |
|
|
|
You can get the RGB triplets and hexadecimal color codes for these palettes using the orderedcolors
and rgb2hex
functions. For example, get the RGB triplets for the "gem"
palette and convert them to hexadecimal color codes.
RGB = orderedcolors("gem");
H = rgb2hex(RGB);
Before R2023b: Get the RGB triplets using RGB =
get(groot,"FactoryAxesColorOrder")
.
Before R2024a: Get the hexadecimal color codes using H =
compose("#%02X%02X%02X",round(RGB*255))
.
Example: BackgroundColor="r"
Example: BackgroundColor="green"
Example: BackgroundColor=[0 0.4470 0.7410]
Example: BackgroundColor="#FF8800"
Background gradient is present in the scene, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
This property specifies whether the background is shaded with a gradient from
GradientColor
to BackgroundColor
. When this property is
"off"
, the GradientColor
property has no effect.
Color of the background gradient shading, specified as an RGB triplet, a hexadecimal
color code, a color name, or a short color name. When BackgroundGradient
is true
, the background
is shaded as a gradient from GradientColor
to BackgroundColor
. When you select light mode in MATLAB, the default color is [0.0667 0.4431 0.7451]
. When you
select dark mode in MATLAB, the default color is [0.3 0.3 0.3]
.
For a custom color, specify an RGB triplet or a hexadecimal color code.
An RGB triplet is a three-element row vector whose elements specify the intensities of the red, green, and blue components of the color. The intensities must be in the range
[0,1]
, for example,[0.4 0.6 0.7]
.A hexadecimal color code is a string scalar or character vector that starts with a hash symbol (
#
) followed by three or six hexadecimal digits, which can range from0
toF
. The values are not case sensitive. Therefore, the color codes"#FF8800"
,"#ff8800"
,"#F80"
, and"#f80"
are equivalent.
Alternatively, you can specify some common colors by name. This table lists the named color options, the equivalent RGB triplets, and the hexadecimal color codes.
Color Name | Short Name | RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|---|---|
"red" | "r" | [1 0 0] | "#FF0000" | |
"green" | "g" | [0 1 0] | "#00FF00" | |
"blue" | "b" | [0 0 1] | "#0000FF" | |
"cyan"
| "c" | [0 1 1] | "#00FFFF" | |
"magenta" | "m" | [1 0 1] | "#FF00FF" | |
"yellow" | "y" | [1 1 0] | "#FFFF00" | |
"black" | "k" | [0 0 0] | "#000000" | |
"white" | "w" | [1 1 1] | "#FFFFFF" | |
"none" | Not applicable | Not applicable | Not applicable | No color |
This table lists the default color palettes for plots in the light and dark themes.
Palette | Palette Colors |
---|---|
Before R2025a: Most plots use these colors by default. |
|
|
|
You can get the RGB triplets and hexadecimal color codes for these palettes using the orderedcolors
and rgb2hex
functions. For example, get the RGB triplets for the "gem"
palette and convert them to hexadecimal color codes.
RGB = orderedcolors("gem");
H = rgb2hex(RGB);
Before R2023b: Get the RGB triplets using RGB =
get(groot,"FactoryAxesColorOrder")
.
Before R2024a: Get the hexadecimal color codes using H =
compose("#%02X%02X%02X",round(RGB*255))
.
Example: GradientColor="r"
Example: GradientColor="green"
Example: GradientColor=[0 0.4470 0.7410]
Example: GradientColor="#FF8800"
Lighting
Light source is enabled, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
This property specifies whether to render the effects of the light source or sources
in the Lights
property.
Since R2023b
Light sources, specified as a Light
object
or array of Light
objects. Each Light
object defines a
light source in the scene. By default, Lights
specifies one light
source above and to the right of the camera.
If you have multiple light sources in a scene, use the Light
object
properties to specify the state (on or off), position, intensity, and size of each light
source. You can enable or disable all light sources simultaneously by specifying the
Lighting
property.
Since R2023b
Strength of ambient light in the scene, specified as a numeric scalar in the range [0, 1]. This property specifies the amount of ambient light in the scene.
Since R2023b
Strength of diffuse light, specified as a numeric scalar in the range [0, 1]. This
property specifies the amount of diffuse light provided by the light sources in the
Lights
property.
Specify the DiffuseLight
property if you have one light source
in a scene, or to update all light sources in a multilight scene to the same value. To
adjust an individual light in a multilight scene, set the Intensity
property of the corresponding Light
object in the Lights
property.
Color of the light source, specified as an RGB triplet, a hexadecimal color code, a
color name, or a short color name. The Viewer
object applies the
specified color to all light sources in the viewer.
For a custom color, specify an RGB triplet or a hexadecimal color code.
An RGB triplet is a three-element row vector whose elements specify the intensities of the red, green, and blue components of the color. The intensities must be in the range
[0,1]
, for example,[0.4 0.6 0.7]
.A hexadecimal color code is a string scalar or character vector that starts with a hash symbol (
#
) followed by three or six hexadecimal digits, which can range from0
toF
. The values are not case sensitive. Therefore, the color codes"#FF8800"
,"#ff8800"
,"#F80"
, and"#f80"
are equivalent.
Alternatively, you can specify some common colors by name. This table lists the named color options, the equivalent RGB triplets, and the hexadecimal color codes.
Color Name | Short Name | RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|---|---|
"red" | "r" | [1 0 0] | "#FF0000" | |
"green" | "g" | [0 1 0] | "#00FF00" | |
"blue" | "b" | [0 0 1] | "#0000FF" | |
"cyan"
| "c" | [0 1 1] | "#00FFFF" | |
"magenta" | "m" | [1 0 1] | "#FF00FF" | |
"yellow" | "y" | [1 1 0] | "#FFFF00" | |
"black" | "k" | [0 0 0] | "#000000" | |
"white" | "w" | [1 1 1] | "#FFFFFF" | |
"none" | Not applicable | Not applicable | Not applicable | No color |
This table lists the default color palettes for plots in the light and dark themes.
Palette | Palette Colors |
---|---|
Before R2025a: Most plots use these colors by default. |
|
|
|
You can get the RGB triplets and hexadecimal color codes for these palettes using the orderedcolors
and rgb2hex
functions. For example, get the RGB triplets for the "gem"
palette and convert them to hexadecimal color codes.
RGB = orderedcolors("gem");
H = rgb2hex(RGB);
Before R2023b: Get the RGB triplets using RGB =
get(groot,"FactoryAxesColorOrder")
.
Before R2024a: Get the hexadecimal color codes using H =
compose("#%02X%02X%02X",round(RGB*255))
.
Example: LightColor="r"
Example: LightColor="green"
Example: LightColor=[0 0.4470 0.7410]
Example: LightColor="#FF8800"
Position of the light source or sources, specified as a 3-element vector of the form
[x
y
z]. Changing the LightPosition
property
changes the point from which the lights illuminates the scene.
Specify the LightPosition
property if you have one light source
in a scene, or to update all light sources in a multilight scene to the same value. To
adjust an individual light in a multilight scene, set the Position
property of the corresponding Light
object in the Lights
property.
Mode for the light positions, specified as one of these values.
"headlight"
— Light is at the camera location and moves with the camera."right"
— Light is above and to the right of the camera and moves with the camera. This is the default value."left"
— Light is above and to the left of the camera and moves with the camera."camera-above"
— Light is above the camera and moves with the camera."target-right"
— Light is to the right of the camera target and moves with the camera."target-left"
— Light is to the left of the camera target and moves with the camera."target-above"
— Light is above the camera target and moves with the camera."target-below"
— Light is below the camera target and moves with the camera."target-behind"
— Light is behind the camera target and moves with the camera."manual"
— The light is at the position specified by theLightPosition
property. The light does not move with the camera."auto"
— The light moves with the camera.
Setting the LightPosition
property changes this
property to "manual"
. Specify the
LightPositionMode
property if you have one light source in a
scene, or to update all light sources in a multilight scene to the same value. To adjust
an individual light in a multilight scene, set the PositionMode
property of the corresponding Light
object in the Lights
property.
Denoising
Since R2023b
Apply edge-preserving denoising, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
When this value is "on"
, the viewer applies edge-preserving
denoising to all objects in the viewer. By default, the value is
"off"
. If the viewer contains a Volume
object
displayed using cinematic rendering, meaning the RenderingStyle
property value is
"CinematicRendering"
, the Denoising
value
automatically changes to "on"
.
Since R2023b
Denoising degree of smoothing, specified as a numeric scalar in the range [0, 1].
This property affects the visualization only when the Denoising
property value is "on"
. A smaller
value preserves details with lower intensity variance, and a larger value smooths
neighborhoods with higher intensity variance, such as strong edges.
Since R2023b
Standard deviation of the smoothing filter kernel, specified as a positive integer
scalar. This property affects the visualization only when the Denoising
property value is "on"
. A larger
value increases the contribution of more distant neighboring pixels, effectively
increasing the neighborhood size.
Interactivity
Interactivity of the volume, specified as "all"
,
"none"
, or a string array that includes any combination of the
strings listed in the table. When specified as "all"
, the viewer
supports all interactions in the table. When specified as "none"
, the
viewer supports no interactions.
Volume Interaction | Description |
---|---|
"zoom" | Zoom in on the scene. |
"rotate" | Rotate the scene. |
"pan" | Pan across the scene. |
"axes" | You can click the labels of the orientation axes to snap to an orthogonal view. |
"clip" | You can further customize the supported clipping interactions with the
ClippingInteractions property. |
"slice" | You can interactively adjust the slice planes of a Volume
object when the RenderingStyle property of the object is
"SlicePlanes" . You can further customize the supported
slice plane interactions with the SliceInteractions property. |
"crop" | You can interactively crop the scene using a rectangular, spherical, or
cylindrical 3-D crop region. You can further customize the supported crop
interactions with the CropInteractions property. |
"scissors" | You can interactively crop regions out of the scene using the 3-D scissors
tool. The viewer supports this tool when the viewer contains Volume objects. The viewer does not support this tool when the
viewer contains one or more Surface or BlockedVolume objects. |
"annotate" | You can interactively add, edit, and remove 3-D point and line annotations.
You can control the placement of annotations with the Annotations property. |
Interactivity of the slice planes, specified as "all"
,
"none"
, or a string array that includes any combination of the
strings listed in the table. When this value is "none"
, you cannot
interact with the slice planes, but you can still update the planes programmatically. To
interact with the slices planes, you must set CurrentObject
as an object that supports slice planes.
Slice Interaction | Description |
---|---|
"add" | Add new planes by clicking the axes toolbar button. |
"remove" | Remove planes using right-click. |
"rotate" | Rotate by dragging the ball. |
"translate" | Translate planes by dragging the plane surface. |
This property affects the visualization only when
is Interactions
"all"
or
a string array that contains "slice"
.
Current object, returned as a child object of the viewer. When an object is added as
a child of the viewer, MATLAB sets the CurrentObject
property to that object. You
can change CurrentObject
by setting this property to the handle of
another object that is a child of the viewer. When GlobalClipping
is false
, you can use this
property to control which object receives clipping plane interactions.
Rendering quality, specified as one of the values in the table.
Value | Description |
---|---|
"auto" | Rendering quality automatically adjusts during interactions to improve performance. After the interaction, the rendering quality is restored. This is the default value when you create the viewer
using the |
"low" | Low rendering quality with high performance. Use this value when setting properties rapidly and repeatedly. |
"medium" | Medium rendering quality, suitable for static and interactive visualization depending on the image data size and GPU capabilities. This is the default value when you create the
viewer using the |
"high" | High rendering quality, at the expense of reduced performance. Use this value when generating high-quality static images. |
Context menu, specified as a ContextMenu
object created using the
uicontextmenu
function. Use this
property to display a context menu when you right-click an area of the viewer that does
not contain any underlying UI components or graphics objects.
To display a context menu when you right-click any portion of a viewer, write code
to set the ContextMenu
property of all underlying UI components and
graphics objects whenever the ContextMenu
property of the viewer is
set.
For example, this code shows how to create a Viewer
object for 3-D
display and specify a context menu. The context menu appears when you right-click the
viewer.
fig = uifigure; cm = uicontextmenu(fig); m1 = uimenu(cm); viewer = viewer3d(fig,ContextMenu=cm);
Cropping
Since R2023b
Position of the crop box in world coordinates, specified as one of the options in
the table. Use the CropInteractions
property to specify whether you can change
this region interactively. This property affects the visualization only when
is Interactions
"all"
or
a string array that contains "crop"
.
Shape | Value |
---|---|
Rectangular | 2-by-3 numeric matrix of the form [xmin ymin zmin; xmax ymax
zmax] , where the first and second rows specify the minimum and
maximum coordinates of the crop box, respectively. |
Spherical (since R2024b) | 4-element numeric row vector of the form [x y z
radius] , where (x, y,
z) and radius specify the center and
radius of the sphere, respectively. |
Cylindrical (since R2024b) | 5-element numeric row vector of the form [x y z radius
height] , where (x, y,
z), radius, and
height specify the center, radius, and height of the
cylinder, respectively. |
Since R2024b
Crop mode for the crop region defined by CropRegion
, specified as "inclusive"
or
"exclusive"
. When set to "inclusive"
, objects
inside the crop region are visible and objects outside the crop region are hidden. When
set to "exclusive"
, objects outside the crop region are visible and
objects inside the crop region are hidden.
Data Types: char
| string
Since R2023b
Interactivity of the crop region, specified as "all"
,
"none"
, or a string array that includes any combination of the
strings listed in the table. When specified as "all"
, the viewer
supports all interactions in the table. When specified as "none"
, you
cannot interact with the crop region, but you can still update the crop region
programmatically by specifying the CropRegion
property.
Crop Interaction | Description |
---|---|
"add" | Add a new rectangular crop region from the viewer toolstrip by
selecting the crop box icon While you can add a rectangular crop region
either from the toolstrip or programmatically, to add a spherical or
cylindrical crop region, you must programmatically specify the
|
"remove" | Remove crop region using right-click. |
"move" | Resize and move the crop region. Resize the crop region by dragging the surface of the crop region. Move the crop region by holding Ctrl while you drag the faces of the crop region. |
This property affects the visualization only when
is Interactions
"all"
or
a string array that contains "crop"
.
Clipping Planes
Clipping planes in the scene, specified as an N-by-4 matrix,
where each row corresponds to the equation for a clipping plane. The maximum number of
clipping planes, N, is six. When GlobalClipping
is true
, these clipping
planes are applied to all objects in the scene, irrespective of any clipping planes set
locally on each object. Each clipping plane is specified as a 1-by-4 vector, in world
coordinates, following the Hessian normal form where the first three values represent
the normal vector of the plane and the fourth value is the signed distance from the
origin to the plane.
Use global clipping planes, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
When this value is "on"
, the planes specified by the
ClippingPlanes
property are applied to all objects. When this
value is "off"
, the ClippingPlanes
property has
no effect and the clipping planes from each object are individually applied.
Clipping plane behavior with multiple planes, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
When this value is "on"
, only intersecting or overlapping regions
of all clipping planes are clipped. When this value is "off"
, a
region is clipped if it is clipped by any clipping plane. Set
ClipIntersection
to "on"
to use multiple
planes to remove a single quadrant of an object.
Interactivity of the clipping planes, specified as "all"
,
"none"
, or a string array that includes any combination of strings
listed in the table. When specified as "all"
, all interactions are
allowed. When specified as "none"
, no interactions are
allowed.
When this value is "none"
, you cannot interact with the clipping
planes, but you can still update the planes programmatically.
Clipping Interaction | Description |
---|---|
"add" | Add new planes by clicking the axes toolbar button. |
"remove" | Remove planes using right-click. |
"rotate" | Rotate by dragging the ball. |
"translate" | Translate planes by dragging the plane surface. |
This property affects the visualization only when
is Interactions
"all"
or
a string array that contains "clip"
.
Viewer Annotations
Toolbar visibility, specified as "on"
, "off"
,
or "hover"
. When this value is "on"
, the toolbar
is always visible. When this value is "off"
, the toolbar is not
visible. When this value is
"hover"
(since R2025a), the toolbar is visible when you position the
pointer inside the viewer window, and hidden when the pointer is outside the viewer
window.
The toolbar contains the interactions specified by the Interactions
property. You can still use the interactions
specified by the Interactions
property when the toolbar is not
visible. To prevent all interaction on the viewer, set Interactions
to "none"
.
Since R2025a
Title for viewer, specified as a string scalar or character vector. The title appears in the top center of the viewer window, within the display.
Tooltip, specified as a string scalar, string array, character vector, cell array of character vectors, or categorical vector. Use this property to display a message when the user hovers the pointer over the component at run time. To display multiple lines of text, specify a cell array of character vectors or a string array. Each element in the array becomes a separate line of text. If you specify this property as a categorical vector, MATLAB uses the values in the vector, not the full set of categories.
Since R2025a
Display object information, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
When this value is "on"
, the lower-left corner of the viewer
displays a zoomed in view and information about the point beneath the pointer. You can
interactively toggle the visibility of the information display from the viewer context
menu.
You cannot display object information and the orientation axes simultaneously. If
you specify DisplayInfo
as "on"
, the
OrientationAxes
value changes to "off"
. If
you specify OrientationAxes
as "on"
, then
DisplayInfo
changes to "off"
.
You can toggle whether the tool displays information about a specific child object
by setting the Pickable
property of that object. Child objects can
be Image
, Volume
, BlockedVolume
, or
Surface
objects.
Display the orientation axes, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
When this value is "on"
, the lower-left corner of the viewer
displays the orientation axes. If no objects are loaded in the viewer, the orientation
axes is not visible.
You cannot display the orientation axes and object information simultaneously. If
you specify OrientationAxes
as "on"
, the
DisplayInfo
value changes to "off"
.
If you specify DisplayInfo
as "on"
, then
OrientationAxes
changes to "off"
.
Display box outline around scene boundary, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
When this value is "on"
, a box is displayed that fits around
every object in the scene. If no 3-D objects are loaded in the viewer, the box is not
visible.
Display scale bar in the lower-right corner, specified as "on"
or "off"
, or as a numeric or logical
1
(true
) or 0
(false
). A value of "on"
is equivalent to
true
, and "off"
is equivalent to
false
. The value is stored as an on/off logical value of type OnOffSwitchState
.
Control the style of the scale bar by using the ScaleBarStyle
property.
Since R2025a
Style of the scale bar, specified as one of the strings in the table. Control the
visibility of the scale bar by using the ScaleBar
property.
Value | Description |
---|---|
"zoom" | Display a scale bar with the zoom level of the image. The zoom level is
based on a combination of available screen size, the image size, and the
viewer camera zoom level. A scale bar zoom level of 100%
indicates that one screen pixel displays one data pixel, or one unit in world
coordinates if you specify the Transformation property of the child
Image , Volume , or
BlockedVolume . |
"measure" | Display a measurement scale bar with units specified by the
SpatialUnits property. |
Spatial units for the viewer, specified as a string scalar. Use this value to change
the units label associated with viewer display tools, such as the scale bar and point
and line annotations. For example, if you specify the
Transformation
property of a Volume
object to
display an object in millimeters, you can optionally specify
SpatialUnits
as "mm"
.
Parent/Child
Parent of the viewer, specified as a Figure
object created using
the uifigure
function, or a
Panel
, GridLayout
, or Tab
object
whose parent is a figure created using the uifigure
function. You
can use the uipanel
, uigridlayout
, and uitab
functions to create the corresponding objects.
If you do not specify a parent when you create the viewer, MATLAB calls the uifigure
function to create a new Figure
object that serves as the parent container.
A GridLayout
object is the recommended parent when you want to
build an app in App Designer, or when you want to add and position other UI components
in a figure with the viewer. When the parent is a GridLayout
object,
you can adjust the layout of the viewer using the Layout
property.
This property is read-only.
Children of the viewer, returned as an array of Image
,
Volume
, BlockedVolume
, and Surface
objects or as an empty GraphicsPlaceholder
array. Setting this
property has no effect.
Position
Size and location of the viewer relative to the parent object, excluding the margins
for decorations such as axis labels and tick marks, specified as a 4-element vector of
the form [left bottom width height]
. By default, the viewer is
positioned to span the entire parent container.
Note
Setting this property has no effect when the parent of the viewer is a
GridLayout
object.
Position units, specified as 'pixels'
,
'normalized'
, 'inches'
,
'centimeters'
, 'points'
, or
'characters'
. This value specifies units for the Position
property. The recommended value is
'pixels'
. To manage the position of multiple UI components in a
parent, create a GridLayout
object using uigridlayout
.
To specify units for the viewer display tools, such as the scale bar and point and
line annotations, see SpatialUnits
.
Layout options, specified as a
GridLayoutOptions
object. This property specifies layout options
only when the parent of the viewer is a GridLayout
object. If the
parent of the viewer is not a grid layout (for example, when the parent is a figure or
panel), then this property is empty and has no effect.
You can place the viewer in the desired row and
column of the grid by setting the Row
and
Column
properties of the GridLayoutOptions
object. For example, this code places a viewer in the third row and second column of its
parent grid.
g = uigridlayout([4 3]); viewer = viewer3d(g); viewer.Layout.Row = 3; viewer.Layout.Column = 2;
To make the viewer span multiple rows or columns, specify the
Row
or Column
property as a 2-element
vector. For example, this viewer spans columns 2
through
3
.
viewer.Layout.Column = [2 3];
Version History
Introduced in R2022bThe 2-D viewer now supports:
Adding a title. Add a title by specifying the new
Title
property.Adding a measurement scale bar by specifying the new
ScaleBarStyle
property as"measure"
.Displaying information about the pixel beneath the pointer. You can interactively copy pixel coordinates and intensity or color values to the clipboard, or export pixel information to the workspace from the viewer context menu. Toggle the visibility of the pixel information display from the viewer context menu or by using the new
DisplayInfo
property.
The viewer toolbar is now always visible by default, regardless of whether the pointer
is inside or outside the viewer window. To preserve the behavior of previous releases,
specify the Toolbar
property as "hover"
, which hides
the toolbar when you move the pointer outside the viewer window.
The viewer scale bar is now always hidden by default. To show the scale bar, specify the
ScaleBar
property as "on"
.
To reflect new support for 2-D image display, the
Viewer3D
object is now theViewer
object. There are no plans to remove support for references toViewer3D
.The default background color for a viewer created using
viewer3d
in light mode has changed from[0 0.329 0.529]
to[0 0.251 0.451]
. The default background gradient color in light mode has changed from[0.0 0.561 1.0]
to[0.0667 0.4431 0.7451]
.
Crop the objects in a viewer to a spherical or cylindrical region, in addition to the rectangular crop region supported in prior releases. To add a spherical or cylindrical crop region, specify the
CropRegion
property as a 4-element or 5-element row vector, respectively. Modify the crop region interactively in the viewer window.Specify whether to view the region inside or outside a crop region by specifying the new
CropMode
property.
Label 3-D points and lines in a scene using annotations. Add annotations interactively
from the Viewer3D
toolbar. By default, the viewer labels point annotations
with their 3-D coordinates, and line annotations with their length. Programmatically query
or update annotations using the new Annotations
property of
Viewer3D
. The new Point
and Line
objects and
their properties define the position, color, and label of point and line annotations,
respectively.
Specify the units label for display tools such as the scale bar and annotations using
the SpatialUnits
property, which replaces the
ScaleBarUnits
property from previous releases. If you have existing
code that specifies units using ScaleBarUnits
, you do not need to
update your code, as Viewer3D
passes the specified value to
SpatialUnits
automatically.
Control the strength of ambient and diffuse light within a viewer using the new
AmbientLight
andDiffuseLight
properties, respectively.Apply denoising to the objects in a viewer using the new
Denoising
property. Specify the amount of smoothing and standard deviation of the Gaussian smoothing kernel using the newDenoisingDegreeOfSmoothing
andDenoisingSigma
properties, respectively.Use a crop box to crop the objects in a viewer to a rectangular subregion. To interactively add a crop box, click the crop box button
in the
Viewer3D
axes toolbar. To crop the display, click and drag on the faces of the crop box. To move the crop box, press Ctrl while you click and drag. You can programmatically define the crop region by setting the newCropRegion
property.Use the 3-D scissors tool to remove regions from of a viewer. To enable the tool, click the scissors button
in the
Viewer3D
axes toolbar. Draw a 2-D polygon that contains the object you want to remove. The tool removes everything from the 3-D cut region, which it defines by extruding the polygon along the axis normal to the drawing plane.
See Also
viewer2d
| viewer3d
| Image Properties | Volume Properties | Surface
| BlockedVolume Properties | Light
| Point
| Line
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Seleccione un país/idioma
Seleccione un país/idioma para obtener contenido traducido, si está disponible, y ver eventos y ofertas de productos y servicios locales. Según su ubicación geográfica, recomendamos que seleccione: .
También puede seleccionar uno de estos países/idiomas:
Cómo obtener el mejor rendimiento
Seleccione China (en idioma chino o inglés) para obtener el mejor rendimiento. Los sitios web de otros países no están optimizados para ser accedidos desde su ubicación geográfica.
América
- América Latina (Español)
- Canada (English)
- United States (English)
Europa
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)