Altium 제품에 접근할 수 있는 레벨에 따라 사용할 수 있는 기능이 달라집니다. 다양한 레벨의 Altium Designer Software Subscription에 포함된 기능과 Altium 365 플랫폼에서 제공하는 애플리케이션을 통해 제공되는 기능을 비교해보세요.
소프트웨어에서 논의된 기능을 찾을 수 없는 경우, Altium 영업팀에 문의하여 자세한 정보를 확인해주세요.
Please note that this documentation was last updated for an older version of Altium Designer. While many of the principles and approaches will remain the same, be aware that interfaces, objects, methods, properties, and the like will have changed since then, and will not reflect the entirety of those found in later versions of the software.
Using the Schematic Editor Interfaces
Copy LinkCopied
The Schematic API allows a programmer to fetch or modify Schematic objects and their attributes from a Schematic document. The objects shown on a document are stored in its corresponding design database.
The Schematic interfaces exposed by the Schematic editor refer to opened Schematic documents and the objects on them.
An interface is a means of access to an object in memory. To have access to the Schematic server and update Schematic design objects, you need to invoke the SchServer function which extracts the ISch_ServerInterface interface. This is the main interface and contains many interfaces within. With this interface, you can proceed further by iterating for certain PCB objects.
The IPCB_ServerInterface and ISch_Document interfaces are amongst the main interfaces that you deal with when extracting data from a Schematic or Schematic Library document. Below is the simplified Schematic object interface hierarchy:
The ISCH_ServerInterface interface is the main interface in the Schematic API. To use Schematic interfaces, you need to obtain the ISch_ServerInterface object by invoking the SchServer function. The ISch_ServerInterface interface is the gateway to fetching other Schematic objects.
The ISch_GraphicalObject interface is a generic interface used for all Schematic design object interfaces.
The ISch_Document interface points to an existing Schematic document in Altium Designer.
When you need to deal with Schematic design objects in Altium Designer, the starting point is to invoke the SchServer function and with the ISch_ServerInterface interface, you can extract the all other derived schematic interfaces that are exposed from the ISch_ServerInterface interface.
Accessing properties and methods of Schematic Interfaces
For each Schematic object interface, there will be methods and properties listed (not all interfaces will have both methods and properties listed, some will only have methods).
A property of an object interface is like a variable, you get or set a value in a property, but some properties are read-only properties, meaning they can only return values but cannot be set. A property is implemented by its Get and Set methods. For example, the Selection property has two methods Function GetState_Selection : Boolean; and Procedure SetState_Selection(B : Boolean);
The ISch_GraphicalObject is the base interface for all descendant Schematic design object interfaces such as ISch_Arc and ISch_Line, therefore all the methods and properties from the base interface are available in the descendant design objects.
For example the Selection property and its associated Function GetState_Selection : Boolean; and Procedure SetState_Selection (B : Boolean); methods declared in the ISch_GraphicalObject interface are inherited in the descendant interfaces such as ISch_Arc and ISch_Line interfaces.
This Selection property is not in the ISch_Arc, but you will notice that the ISch_Arc interface is inherited from the base ISch_GraphicalObject interface and this interface has a Selection property along with its associated methods (GetState function and SetState procedure for example).
If you can't find a method or a property in an object interface that you expect it to be in, then the next step is to look into the base ISch_GraphicalObject interface — this can be used to access most of the objects in Schematic.
Typecasting Schematic Interface Objects
With server development, you need to deal with types of variables and objects. Interface types follow the same rules as class types in variable and value typecasts. Class type expressions can be cast to interface types, for example ISch_Pin(SchPin) provided the SchPin variable implements the interface. With scripts, they are typeless and you normally do not need to type cast objects.
You cannot directly typecast Delphi objects that are not directly implemented as interface objects if these Delphi objects do not have interfaces. For example, this code snippet produces an exception because you are typecasting a Delphi object that does not directly implement the interface.
The solution to this problem is to use the Support keyword as part of Embarcadeo Delphi’s™ VCL library. This Supports keyword checks whether a given object or interface supports a specified interface. You can call this Supports function to check if the Delphi object contains references to interface objects.
The Schematic editor uses a 32-bit database system and stores two types of objects - drawing and electrical objects. The database system has two different data structures which are the flat database and the spatial database. In this secondary database system, each container holds the same object kind, for example the bus entry container consists of a linear list of bus entry objects which are organized by their coordinates.
The type of database is selected automatically depending on how you wish to access schematic objects. Every existing schematic object on a schematic sheet is identified by its TSchObjectHandle value. Each Schematic object wrapped by its interface has an I_ObjectAddress function.
Schematic documents
There are two types of documents in Schematic editor; the Schematic document and the Schematic Library document. Dealing with Schematic documents is straightforward, you obtain the Schematic document in question and then you can add or delete Schematic objects.
The concept of handling a Schematic Library document is a bit more involved as each Schematic symbol (a component with its designator undefined) is part of the one and same Schematic library document and there are library documents within a Schematic library file. Therefore, you need the schematic library container before you can iterate through the symbols of a library or add/delete symbols.
Loading Schematic or Library documents in Altium Designer
There are other situations when you need to programmatically open a specific document. This is facilitated using the Client.OpenDocument and Client.ShowDocument methods.
Opening a text document, you pass in the ‘Text’ string along with the full file name string. For Schematic and Schematic Library documents, the ‘SCH’ and ‘SCHLIB’ strings respectively need to be passed in along with the full file name string. For PCB and PCB Library documents, the ‘PCB’ and ‘PCBLIB’ strings respectively need to be passed in along with the full file name string.
Since the parameters are null terminated types for some of the functions and often the strings are TDynamicString types, you will need to typecast these strings as PChar type.
In the code snippet below, the Filename parameter is a TDynamicString type and this parameter is typecasted as a PChar in the Client.OpenDocument method.
Opening a Schematic Document using Client.OpenDocument method
Creating Schematic or Library documents in Altium Designer
There are situations when you need to programmatically create a blank stand-alone document. This is facilitated by using the CreateNewDocumentFromDocumentKind function. For example, to create a text document you pass in the ‘Text’ string.
See the script examples in the Scripts\DelphiScript Scripts\DXP\ folder.
Generally you would like to create a document programmatically and put in the currently focused project. To do this, you would need interface access to the Workspace Manager in Altium Designer and invoke DM_FocusedProject and DM_AddSourceDocument functions.
Checking the type of Schematic Documents in Altium Designer
You can use the GetCurrentSchematicDocument function from the SchServer object to check whether the current schematic document is a schematic type document.
There are situations when you need to programmatically set a document to dirty so when you close Altium Designer, it prompts you to save this document. This is facilitated by setting the ServerDocument.Modified function to true.
// grab the current document view using the CLient's Interface.
06
AView := Client.GetCurrentView;
07
08
//grab the server document which stores views by extracting the ownerdocument field.
09
AServerDocument := AView.OwnerDocument;
10
11
// set the document dirty.
12
AServerDocument.Modified := True;
13
End;
See the script examples in the Scripts\DelphiScript Scripts\DXP\ folder.
Refreshing a document programmatically
When you place or modify objects on a schematic document, you often need to do a refresh of this document (you will also need to use the PreProcess / PostProcess and SchServer.RobotManager.SendMessage() methods).
ISch_Document.GraphicallyInvalidate;
RunProcess(); (Script code)
Commands.LaunchCommand(); (Server code)
Examples below demonstrate more than one way to update the document. You can use the ICommandLauncher.LaunchCommand method or the IProcessLauncher’s SendMessage function.
GraphicallyInvalidate and RunProcess methods in a script
Note, in a server project, the SendMessage method is available from the IProcessLauncher interface.
Schematic Objects
Schematic design objects are stored inside the database of the Schematic editor for the currently active schematic document, basic Schematic objects are called primitives. There are two types of primitives in the Schematic editor: Electrical primitives and non-electrical primitives. Each design object has a unique object handle which is like a pointer. These handles allow you to access and change the design object’s properties.
The Schematic editor includes the following electrical primitives: Bus, Bus Entry, Junction, Port, Power Port, PCB layout directive, Pin, No ERC Directive, Sheet Entry, Sheet Symbol, Stimulus Directive, Test Vector Directive, and Wire objects. Add any new ones to the list
Non electrical primitives include: Annotation, Arc, Bezier, Ellipse, Elliptical Arc, Graphical Image, Line, Pie, Polygon, Rectangle, Rounded Rectangle, and Text Frame objects add any new ones to the list. The non-electrical primitives are used to add reference information to a sheet. They are also used to build graphical symbols, create custom sheet borders, title blocks or adding notes and instructions.
The Schematic editor has other system objects such as a container for templates, preferences settings, a search facility, a font manager, a robot manager (capture events of the schematic editor) and so on.
Schematic objects that have child objects are called group objects. Part objects and sheet symbol objects are examples of group objects. Part Objects have pin child objects and Sheet Symbols have sheet entry child objects. ISch_BasicContainer interface is the ancestor interface for all Schematic design objects including schematic sheets and library documents. This interface has methods that return the unique object address and set up an iterator with filters to look for specific objects within a defined region.
ISch_GraphicalObject interface is the interface for all schematic design objects with graphical attributes.
The three interfaces, ISch_MapDefiner, ISch_ModelDatafileLink, ISch_Implementation all deal with the mapping of schematic components to its models such as PCB footprint, 3D Model, Signal Integrity model and so on.
Accessing Schematic Objects
An iterator provides a way of accessing the elements of an aggregate object sequentially without exposing its underlying representation. The use of iterators provides a compact method of accessing Schematic objects without creating a mirror database across the API. To retrieve objects on a schematic sheet or a library document, you will need to employ an iterator which is an efficient data retrieval method – there are three types of iterators – simple iterators, spatial iterators and group iterators.
Object iterators are used to conduct global searches.
Spatial iterators are used to conduct restricted searches.
Group iterators are used to conduct searches for primitives inside certain schematic objects.Schematic objects which have objects within them are called group objects such as sheet symbols and part objects.
You can specify which objects to look for in the specified region of a document with a spatial iterator. You also set up global iterators that look inside the child objects of a parent object, for example sheet entries of a sheet symbol or parameters of a schematic component.
// add pins to the PinsList container of a TStringList type.
18
PinsList.Add('Pin '+ Pin.Designator +
19
' located at (x='+ IntToStr(Pin.Location.X) +
20
', y='+ IntToStr(Pin.Location.Y) + ')');
21
Pin := PinIterator.NextSchObject AsISch_Pin;
22
End;
23
Finally
24
AComponent.SchIterator_Destroy(PinIterator);
25
End;
26
IfNotPinFound Then
27
PinsList.Add('There are no pins for this component.');
28
End;
This code snippet demonstrates the method of fetching schematic objects from a schematic sheet using an iterator.
See the script examples in the Scripts\DelphiScript Scripts\Sch\ folder.
Creating/deleting new Schematic Objects
Schematic objects created using the Schematic API will need to follow a few simple steps to ensure that the database system of the Schematic editor will successfully register new objects. The example below demonstrates the placement of a Port object onto a Schematic document programmatically.
// Add a new port object in the existing Schematic document.
27
FSchDoc.AddSchObject(SchPort);
28
FSchDoc.GraphicallyInvalidate;
29
30
// use of Server processes to refresh the screen.
31
ResetParameters;
32
AddStringParameter('Action', 'Document');
33
RunProcess('Sch:Zoom');
34
End;
How the above code works
A new port object is created by the SchObjectFactory method. This function takes in two parameters, the ePort value of TObjectID type and the creation model parameter of TObjectCreationMode type. The port’s attributes need to be set accordingly then you will need to register this port object into the Schematic database.
The AddSchObject method needs to be invoked for the SchServer object which represents the schematic database. Finally the GraphicallyInvalidate call refreshes the schematic document.
Note that a RGB function is used in the code to assign a color value to the areacolor and textcolor fields. This function is a Windows API function and takes in three parameters for the three color intensities (red, green and blue). In this case, (255,255,255) represents the white color and (0,0,0) represents the black color.
See the script examples in the Scripts\DelphiScript Scripts\Sch\ folder.
Creation of a new Schematic Object on a Library document
You can create a symbol on an existing library document in the same way as you create objects on a schematic document.
Creating a new Library Component on a new Library document
See the script examples in the Scripts\DelphiScript Scripts\Sch\ folder.
Creating Objects and refreshing the Undo/Redo system in the Schematic Editor
The simple creation of objects in the examples above does not refresh the Undo system in the Schematic Editor. To do this, you will need to employ the SchServer.RobotManager.SendMessage method.
The sequence is as follows:
PreProcess which initialize the robots in the Schematic server
Add new objects
PostProcess which cleans up the robots in the Schematic server.
Creating Schematic objects in a project
This example describes the correct method for allowing Undo/Redo at various different levels of objects (the first at adding components to the document and the second at adding parameters to the pin of a placed component).
Specifically this will add a constructed component to the current sheet and then a parameter to the pin.You will then be able to perform an undo., The first press of Undo removes the parameter added to the pin. The second press of Undo removes the the component that was added to the document.
See the script examples in the Scripts\DelphiScript Scripts\Sch\ folder.
Modifying Schematic Objects
To modify Schematic objects on a current Schematic document, you will need to invoke certain methods in a particular order to ensure the Undo/Redo system is up to date when a schematic object’s attributes have been modified programmatically.
The sequence is as follows:
Invoke the PreProcess method which initialize the robots in the schematic server
Send a SCHM_BeginModify message
Modify the Schematic object by changing its attributes (Properties)
Send a SCHM_EndModify message
Invoke the PostProcess method to clean up the robots in the Schematic server.
Changing Schematic Object’s Attributes code example
Notes
When you change the properties of a schematic object on a Schematic document, it is necessary to employ the SchServer.RobotManager.SendMessage function. This updates the various subsystems of the Schematic system such as the Undo/Redo system and setting the document as dirty so the document can be saved. Look for the SendMessage method of the ISch_RobotManager in this document.
Remember, the Schematic API only can be used to work on a currently open Schematic document in the Altium Designer. If you need to fetch specific Schematic documents, you will need the Client object’s OpenDocument and ShowDocument methods to open and display a document.
See the script examples in the Scripts\DelphiScript Scripts\Sch\ folder.
Schematic interactive feedback using the Mouse
To monitor the mouse movement and clicks from your script, the ISch_Document document interface and its descendant interfaces, ISch_Lib and ISch_Sheet interfaces have several interactive feedback methods. For example, the ChooseRectangleinteractively method can be used for the Spatial iterator where it needs the bounds of a rectangle on the schematic document to search within.
Consult the ISch_Document interface entry in the Schematic API Reference document.
See the script examples in the Scripts\DelphiScript Scripts\Sch\ folder.
Activating the Schematic API
There are situations when Altium Designer is in a blank editing session. When Schematic documents have not been opened, the Schematic API is not active. At these times, you need to manually start the server to access to the Schematic API. Starting up the Schematic server to activate the Schematic API is done by invoking the Client.StartServer method with a ‘SCH’ parameter. Client.StartServer('SCH');
If you find an issue, select the text/image and pressCtrl + Enterto send us your feedback.
Altium 제품에 접근할 수 있는 레벨에 따라 사용할 수 있는 기능이 달라집니다. 다양한 레벨의 Altium Designer Software Subscription에 포함된 기능과 Altium 365 플랫폼에서 제공하는 애플리케이션을 통해 제공되는 기능을 비교해보세요.
소프트웨어에서 논의된 기능을 찾을 수 없는 경우, Altium 영업팀에 문의하여 자세한 정보를 확인해주세요.
The target page does not exist for the current version of documentation. We have redirected you to the nearest available version of this page. Note that this may be for an earlier/later version of the software, depending on the version of documentation that was being viewed when clicking the link.
You are now viewing version 20.1 of the documentation. Use the version selector to change this as needed.