-
Notifications
You must be signed in to change notification settings - Fork 263
Important ATF Components
Managed Extensibility Framework (MEF) components can easily be added to provide capabilities needed by many applications, such as common menus and menu items. Each of the components here is used in at least one ATF sample. Some components, such as ControlHostService
and other components described in Application Shell Framework, are fundamental and would be used in nearly all applications.
You can also create your own components that perform similar functions and export the same types as these components. You can write the component from scratch, or derive from an existing component, as described in Deriving from Components.
For a list of various representative and useful ATF classes, listed by namespace, see Class Survey. This list includes many of the components listed here.
Core ATF Frameworks also lists components that are commonly used in ATF applications.
These components are all in the Sce.Atf.Applications
namespace, unless otherwise noted.
-
ControlHostService
: provide a dock in which to hold controls, such as menus and toolbars. Its interface isIControlHostService
. The docking control allows moving windows around on the dock, and the window configuration can be saved. For details, see ControlHostService Component. -
CommandService
: display currently available application commands to the user in menus and toolbars and provide keyboard shortcuts. Its interface isICommandService
. For more information, see CommandService Component. -
StatusService
: add a status bar at the bottom of the main form. Its interface isIStatusService
. For details, see StatusService Component. -
SettingsService
: manage user-editable settings (preferences) and the persistence of these application settings, plus a settings command and dialog. Its interface isISettingsService
. For more information, see SettingsService Component.
For more information on the application shell, see ATF Application Basics and Services.
-
StandardFileCommands
: implement File menu commands that modify the document registry: New, Open, Save, SaveAs, Save All, and Close. New and Open commands are created for each component that exportsIDocumentClient
in the application. -
AutoDocumentService
: open documents from the previous application session or create a new empty document when an application starts. -
RecentDocumentCommands
: add recently opened documents to the application's File > Recent Documents submenu. -
DocumentRegistry
: hold documents, provide notifications when a document is added or removed, track the most recently active document and the open document contexts, and filter by document type. It implementsIDocumentRegistry
. -
MainWindowTitleService
: update the main dialog's title to reflect the current document and its state, i.e., modified or not. -
FileDialogService
: provide standard file dialogs for an application, using the ATFOpenFileDialog
,SaveFileDialog
, andConfirmationDialog
classes. Required byStandardFileCommands
.
For more information on the document framework, see Documents in ATF.
-
ContextRegistry
: tracks the active contexts in the application with change notification. It implementsIContextRegistry
.
For details on working with contexts, see ATF Contexts.
-
PropertyEditor
: edit object values and attributes using the ATFPropertyGrid
, which is a two-column editing control. For more information, see PropertyEditor Component. -
GridPropertyEditor
: edit object values and attributes using the ATFGridControl
, an ATF spreadsheet-style editing control. For more information, see GridPropertyEditor Component. -
PropertyEditingCommands
: provide property editing commands in a context menu that can be used inside property editor controls likePropertyGrid
.PropertyEditingCommands
can be used with ATF property editors or with custom property editors. For more details, see PropertyEditingCommands Component.
For more details on property editing components, see Property Editor Components. For more information about property editing in general, see Property Editing in ATF. Several samples, such as ATF DOM Property Editor Sample and ATF Simple DOM Editor Sample show using property editors. For details on these samples, see DOM Property Editor Programming Discussion and Simple DOM Editor Programming Discussion.
-
StandardEditCommands
: provide the Edit menu commands Cut, Copy, Paste, and Delete, using theIInstancingContext
and (if available)ITransactionContext
interfaces to perform the operations. For more details, see StandardEditCommands and Instancing. -
StandardEditHistoryCommands
: implement Edit menu Undo and Redo commands. -
StandardSelectionCommands
: add standard selection commands in Edit menu: Select All, Deselect All, and Invert Selection.
For information about instancing, see Instancing In ATF.
-
StandardFileExitCommand
: add the File > Exit command that closes the application's main form. For information on using this component in an application, see StandardFileExitCommand. -
StandardPrintCommands
: add standard printing commands to File menu: Print, PageSetup, and PrintPreview. -
StandardViewCommands
: add the standard viewing commands on contexts implementing theIViewingContext
interface. -
SourceControlCommands
: implement source control commands.
For information on creating and working with commands, see Commands in ATF.
-
TreeControlEditor
: generic tree editor. -
FilteredTreeControlEditor
: filtering support for tree editors. -
TreeListViewEditor
:TreeListViewAdapter
(tree with lists) with right click context menu editing.
To learn more about controls, see Controls in ATF.
-
WindowLayoutService
: save application window layouts, switch window layouts, and delete layouts. -
WindowLayoutServiceCommands
: commands for handling application window layouts in the Window > Layouts submenu: Save Layout As, Manage Layouts, and Default. -
PaletteService
: manage the global palette of objects that can be dragged onto other controls, creating an instance of the object. -
TabbedControlSelector
: enable the user to switch control focus using the Ctrl+Tab keyboard command, similar to Visual Studio, Windows®, or any tabbed Internet browser application. -
DefaultTabCommands
: provide the default commands related to document tab Controls, such as those that appear in the context menu when right-clicking on a tab.
-
OutputService
: display text output to the user in aRichTextBox
. You should also includeOutputs
component when you useOutputService
. -
Outputs
: provide static methods for easy access to the output message facilities in the application. InSce.Atf
namespace. -
ErrorDialogService
: display error messages to users in an error dialog. -
ScriptingService
: abstract base class for components that can expose C# objects to a scripting language, such as Python. -
AtfScriptVariables
: expose common ATF services as script variables, so that the givenScriptingService
can easily use these ATF services. -
ScriptConsole
: provide a dockable command console for entering Python commands and import many common .NET and ATF types into the Python namespace. -
PythonService
: scripting service for automated tests. -
AutomationService
: provide facilities to run an automated script using the .NET remoting service. -
CrashLogger
: log unhandled exceptions to a remote server. If used withUnhandledExceptionService
component, putCrashLogger
beforeUnhandledExceptionService
in theTypeCatalog
. InSce.Atf
namespace. -
UnhandledExceptionService
: catch all unhandled exceptions from the UI thread and present the user with the option of continuing the application so work can be saved. -
HelpAboutCommand
: add the Help > About command, which displays a dialog box with a description of the application plus the ATF version number. Applications should derive from this component. -
DomRecorder
: record DOM events on the active context and displays them in a list in a window.
For more information on scripting and debugging, see Development, Debugging, and Testing.
-
OscService
: process (Open Sound Control) OSC messages by getting and setting properties on C# objects. -
LemurOscService
: provide OSC support compatible with the Lemur iPad® application, from the Liine company.
For more information on OSC, see OSC Support.
Samples also implement components applications can use or adapt. Each component lists the samples in which it appears.
-
DomTypes
: use theDomNodeType
,ChildInfo
, andAttributeInfo
DOM metadata classes to describe an application's Document Object Model (DOM). Normally these are defined by a schema file. This component is in the ATF Simple DOM No XML Editor Sample. -
GroupingCommands
: define circuit-specific commands for group and ungroup. Grouping takes modules and the connections between them and turns them into a single element that is equivalent. ATF Circuit Editor Sample. -
LayeringCommands
: component to add an Add Layer command to an application. ATF Circuit Editor Sample. -
MasteringCommands
: component that defines circuit-specific commands for Master and Unmaster commands. Mastering creates a new type of circuit element from a subcircuit. Any changes to this master element affect all its instances. ATF Circuit Editor Sample. -
ModelViewer
: view a 3D model. ATF Model Viewer Sample. -
ModulePlugin
: add module types to an editor. This class adds sample audio modules. ATF Circuit Editor Sample. -
PaletteClient
: populate a palette with types, such as basic Finite State Machine (FSM) types. ATF Diagram Editor Sample, ATF DOM Tree Editor Sample, ATF Fsm Editor Sample, ATF Simple DOM Editor Sample, ATF Simple DOM No XML Editor Sample, and ATF State Chart Editor Sample. -
RenderView
: render a 3D scene from the active document. ATF Model Viewer Sample. -
ResourceListEditor
: register a slaveListView
control to display and edit resources that belong to the most recently selected event. It handles drag and drop and right-click context menus for theListView
control. ATF Simple DOM Editor Sample and ATF Simple DOM No XML Editor Sample. -
SchemaLoader
: load the user interface schema, register data extensions on the DOM types, and annotate the types with display information and property descriptors. ATF Circuit Editor Sample, ATF Diagram Editor Sample, ATF DOM Tree Editor Sample, ATF Fsm Editor Sample, ATF Simple DOM Editor Sample, ATF Simple DOM Editor WPF Sample, ATF State Chart Editor Sample, and ATF Timeline Editor Sample. -
SourceControlContext
: implement a context for source control. ATF Code Editor Sample. -
TimelineEditor
: create and save timeline documents. ATF Timeline Editor Sample. -
TimelineCommands
: define Timeline-specific commands. ATF Timeline Editor Sample. -
TreeLister
: display a tree view of user interface data. Use the context registry to track the active UI data as documents are opened and closed. ATF DOM Tree Editor Sample.
- What is MEF: Brief description of MEF with links to more detailed information.
- How MEF is Used in ATF: Examine how ATF is used in sample applications to compose components and how components are decorated.
- Initializing Components: How component initialization is implemented in ATF.
- Using ATF Components: How to use ATF components, discovering what you need to provide in your application.
- Creating MEF Components: How to create components of your own, using the attributes you need.
- Important ATF Components: Description of some key ATF components in functional areas as well as some components in sample applications.
- Finding ATF Components: How to find components you need for your application.
- Details on Selected ATF Components: Provides more details on some ATF components you might want to use in your applications.
- Details on Using Selected ATF Components: Shows exactly how to use certain components.
- Home
- Getting Started
- Features & Benefits
- Requirements & Dependencies
- Gallery
- Technology & Samples
- Adoption
- News
- Release Notes
- ATF Community
- Searching Documentation
- Using Documentation
- Videos
- Tutorials
- How To
- Programmer's Guide
- Reference
- Code Samples
- Documentation Files
© 2014-2015, Sony Computer Entertainment America LLC