Object Hierarchy | Related C++ Class: View
View
v4.0
The View object represents an instance of a view in Softimage.
Most windows embedded in the current Layout as well as free floating windows are
represented as View objects.
Softimage comes with many types of views built in, including
Netview, the Script Editor, the Render Tree, and the Explorer.
Toolbars and Shelves are also a type of view (except for Toolbars
created with early versions of Softimage). And Relational Views are
a type of view that combine other view types together within a
single view window.
The Property Page window (see the PPG
object) is not a type of View, but it can be embedded inside a view
of type "Property Panel", as demonstrated in the example
below.
The View object also allows you to manipulate the four Softimage
viewports by creating an instance of the View Manager via Layout.Views("vm") and then customizing it
using View.SetAttributeValue with the
View Manager
Attributes.
Views are accessible from the Layout.Views method (or from the View.Views method if the view is a relational
view). To instantiate a View object inside a free floating window
call Layout.CreateView.
With view objects, you can:
- Change the view state such as closed and minimized state.
- Change the view position and size.
- Hide/unhide the view.
- Access to specific view attributes such as the Explorer scope and
NetView URL.
- Edit view attributes in bulk mode to avoid the UI to
flicker.
- Iterate over the sub views of a relational view.
Some of these tasks can be performed using methods implemented on
the View object (View.Move, View.Resize, View.Visible, etc.); however, many
specialized tasks, such as changing the scope and
selection in the Explorer or maximizing a single
viewport window can only be accomplished via the View.SetAttributeValue and
View.GetAttributeValue
methods. See View
Attributes Reference for a list of attributes available for
different views.
BeginEdit | EndEdit | FindView | FindView2 |
GetAttributeValue | IsClassOf | IsEqualTo | Move |
Rearrange | Refresh | Resize | SetAttributeValue |
Application | Categories | Floating | FullName |
Help | MemoCameras | Name | NestedObjects |
Origin | OriginPath | Parent | Rectangle |
State | Type | Views | Visible |
/* This example restores and cascades all floating views excepted the script editor. */ // Create some sample views var layout = Desktop.ActiveLayout; layout.CreateView( "Explorer", "My Explorer" ); layout.CreateView( "Browser", "My Browser" ); layout.CreateView( "NetView", "My NetView" ); // Position for the first view to cascade px = 50 py = 20 // Delta between each view dx = 20 dy = 20 var views = layout.Views; for( var i=0; i<views.Count; i++) { var vw = views(i); if( vw.Floating && vw.Name != "script_editor") { vw.Move( px, py ); px += dx; py += dy vw.State = siNormal; // put view at the top so far } } |
# Set up a few basics from win32com.client import constants as c import os.path app = Application false = 0 true = 1 null = None # Convenience function to create a simple synoptic page on disk def MakeSynViewPages() : mysynviewpath = XSIUtils.BuildPath( app.InstallationPath(c.siFactoryPath), "Data", "XSI_SAMPLES", "Synoptic" ) file1 = XSIUtils.BuildPath(mysynviewpath, "SynViewStartWith.htm") file2 = XSIUtils.BuildPath(mysynviewpath, "SynViewSwitchTo.htm") f = open(file1, 'w') f.write("<html>\n<body version=\"2\">\n<script language=\"VBScript\">\n\n") f.write("sub hotspot(in_obj,in_mousebutton,in_keymodifier)\nset self = GetValue(i") f.write("n_obj)\nApplication.LogMessage \"VB: Touched \" & self.FullName & \" at \" _") f.write("\n\t& self.posx.Value & \",\" & self.posy.Value _\n\t& \",\" & self.posz") f.write(".Value & \" (x,y,z)\"\nend sub\n</SCRIPT>\n\n<map name=\"SynopticMap\">\n") f.write("<area shape=\"circle\" coords=\"260,251,129\" title=\"\" NOHREF onClick=") f.write("\"hotspot\">\n</map>\n\n<img src=\"..\\pictures\\xsilogo.jpg\" usemap=\"#S") f.write("ynopticMap\">\n\n</body>\n</html>") f = open(file2, 'w') f.write("<html>\n<body version=\"2\">\n<script language=\"JavaScript\">\n") f.write("\nfunction hotspot(in_obj,in_mousebutton,in_keymodifier)\n{\nvar self = G") f.write("etValue(in_obj);\nApplication.LogMessage( \"JS: Touched \" + self.FullName + ") f.write("\" at \" \n\t+ self.posx.Value + \",\" + self.posy.Value \n\t+ \",\" + ") f.write("self.posz.Value + \" (x,y,z)\" );\n}\n</SCRIPT>\n\n<map name=\"SynopticMap") f.write("\">\n<area shape=\"circle\" coords=\"260,251,129\" title=\"\" NOHREF onCli") f.write("ck=\"hotspot\">\n</map>\n\n<img src=\"..\\pictures\\xsilogo.jpg\" usemap=") f.write("\"#SynopticMap\">\n\n</body>\n</html>") return [file1, file2] # Create a synoptic property and attach it to a torus app.NewScene("", false) torus = app.CreatePrim("Torus", "MeshSurface") app.Rotate(torus, 90, 0, 0, c.siAbsolute, c.siPivot, c.siObj, c.siX) app.Translate(torus, 4, 3, 2, c.siAbsolute, c.siPivot, c.siObj, c.siZ) synfiles = MakeSynViewPages() applied = torus.AddProperty("Synoptic Property") applied.Parameters(1).Value = "SynViewAttrib" applied.Parameters(2).Value = synfiles[0] app.OpenAttachments() # Open the Synoptic viewer lay = app.Desktop.ActiveLayout vw = lay.Views("Synoptic View") vw.SetAttributeValue("path", synfiles[1]+","+torus.Name) |
/* This example demonstrates how we can host a Custom Property inside a View. This has some advantages over the InspectObj command: -we can specify the exact size and positioning of the window -the view is exposed in the Layout.Views collection so we can find out if the property page is already being "inspected". However it does not support the "Modal" mode supported by InspectObj. */ // Step 1: Create the custom property var oPSet = ActiveSceneRoot.AddProperty( "CustomProperty", false, "MyProp" ); oPSet.AddParameter3( "textparam", siString ) ; oPSet.AddFCurveParameter( "MyFCurve" ) ; var oLayout = oPSet.PPGLayout ; oLayout.Clear() ; oLayout.AddItem( "textparam" ); oLayout.AddItem( "MyFCurve" ); oLayout.AddRow() oLayout.AddButton( "MoveView", "Move View" ) ; oLayout.AddButton( "Close" ) ; oLayout.EndRow() oLayout.Language = "JScript" oLayout.Logic = MoveView_OnClicked.toString() + Close_OnClicked.toString() ; // Step 2: Show the custom property in a view var oActiveLayout = Application.Desktop.ActiveLayout; var oNewView = oActiveLayout.CreateView( "Property Panel", "MyPropView" ); oNewView.BeginEdit(); oNewView.Move( 10, 10 ); oNewView.Resize( 340, 340 ); oNewView.SetAttributeValue( "targetcontent", oPSet.FullName ); oNewView.EndEdit(); // Logic code used by the buttons on the Custom Property function MoveView_OnClicked() { // We can't get to the view directly from the PPG object, // but we can find it indirectly by searching through // the open views var thisCustomProp = PPG.Inspected.Item(0).FullName var oActiveLayout = Application.Desktop.ActiveLayout for ( var i = 0 ; i < oActiveLayout.Views.Count ; i++ ) { var oView = oActiveLayout.Views(i) ; if ( oView.Type == "Property Panel" ) { if ( oView.GetAttributeValue("targetcontent") == thisCustomProp ) { // found it! oView.Move( 250, 250 ) ; return ; } } } } function Close_OnClicked() { // Self destruction of the custom property DeleteObj( PPG.Inspected.Item(0) ) ; PPG.Close() ; } |
// Open an Animation Editor and show the FCurves on // a custom property var oPSet = ActiveSceneRoot.AddProperty("CustomProperty",false,"Demo" ) ; var oParam = oPSet.AddParameter3( "Value", siDouble, 0, 0, 100 ) ; var oParam2 = oPSet.AddParameter3( "Value", siDouble, 0, 0, 100 ) ; oParam.AddFCurve2( new Array( 1, 0, 25, 50, 50, 25, 100, 100 ) ) ; oParam2.AddFCurve2( new Array( 1, 100, 25, 25, 50, 50, 100, 100 ) ) ; var oLayout = Desktop.ActiveLayout; var oView = oLayout.CreateView( "Animation Editor", "MyFCurves" ); oView.SetAttributeValue( "TargetContent", oPSet.FullName ) ; |