역사 및 적용편집
The first version of the standard was adopted in 2001. Its first use was for Airbus A380 CDS development. 표준의 첫번째 버전은 2001년 채택되어, Airbus A380 CDS 개발에 처음으로 적용되었다. 첫번째 부속서는 2003년에 새로운 위젯들이 추가되어 채택되었다. 두번째 부속서는 2005년 6월에 새로운 부속 위젯들이 추가되어 채택되었다. 세번째 부속서는 2007년에 채택되었다. 2010년에 4번째 부속서가 채택되었다.
이 표준은 Airbus A380과 A400M, Boeing 787 CDS 개발에 사용되었다고 알려져 있다. The standard is known today to be used for Airbus A380 and A400M CDS development, and also Boeing 787 CDS development. AgustaWestland company use ARINC 661 for the development of a new Touchscreen unit in the upgraded Merlin helicopter for the Royal Navy. In March 2011, Embraer announced that it selected SCADE Solutions for ARINC 661, a COTS (Commercial Off The Shelf) tool for ARINC 661 development, for its future developments.
|Initial version||2001||First use for Airbus A380 development|
|1||2003||New widgets, vertical maps|
|2||June 2005||New widgets|
The standard normalizes :
- the GUI definition of the CDS interface, in a binary file called DF (Definition File) defining the structure of the graphical interface tree. The GUI tree is instantiated at initialization time (called the Definition Phase in the standard) in the CDS, using the definition contained in the DF.
- the communication at runtime between the User Applications (UA) and the CDS. This communication protocol is typically used for UAs to send widgets modifications to the CDS, and return user events (such as buttons selection) from CDS to UA.
In order to be compliant with the standard, a CDS must have a kernel that can create the widgets tree during CDS initialization, using the Definition File, and communicate with UA in both ways using the runtime protocol.
ARINC 661 does not imply the use of a particular Data bus structure to perform the low-level communication between CDS and UA. For example, an ARINC 429 or ethernet protocol can be used, but it is not mandatory.
Each DF binary file specify the GUI definition for one User Application (UA) User interface. Several UA user interface trees can be combined to constitute the CDS display definition.
A DF is composed of two parts : an optional symbol definition, and a widgets definition. The widget library is similar to Widgets used in computing. There are Containers, Lists, ScrollPanes, Buttons, Menus, Labels, EditBoxes, etc...
Although the DF File is binary, the standard has also defined an associated XML definition, which is easier to manipulate in tools.
Relationship with other UI languages편집
Main similarities from other User interface markup languages:
- The interface definition is not hard-coded in the CDS. Instead, the CDS use a kernel which instantiate the widget tree at initialization, using a predefined widget library
- The widget list and the structure of the widget tree are similar to what can be found in common Widget toolkits
- The Look and feel is separated from the definition of the interface
Main differences from other User interface markup languages :
- The widget library defined in the standard does not really take advantage of its object nature, contrary to other User interface markup languages. For example, there is no notion of inheritance in the standard, although the same properties can be used more than once for several widgets.
- Some Widget toolkits or User interface markup languages have the ability to lay out widgets automatically in a container (see for example the box model in XUL, or the layouts in Java Swing). Widgets position and size in their container must always be defined exactly in an ARINC 661 definition. However, the supplement 3 of the standard has added a limited sort of "relative" layout capability between widgets (see Layout manager).
- There is no equivalent of XBL, like what is used in XUL or SVG. There are symbols that can be reused, but they are mainly shapes that cannot have behaviors (apart from defining their position, rotation, and color), or specific bindings.
- There is no equivalent of Cascading Style Sheets, as they are used in XUL or SVG for example. Instead, the Look and feel of the interface is hard-coded in the ARINC 661 kernel.
- The standard has defined specific "Map" widgets which allows to present elements such as Flight plans in CDS.
The following example presents the XML Definition File for a Layer containing a panel enclosing a label, which shows the text "Hello World!". Note that contrary to most widget toolkits, ARINC 661 widgets origins are relative to the lower left-hand corner of their parent container, and screen units are not in pixel but in 1/100 of millimeters.
<?xml version="1.0"?> <!DOCTYPE a661_df SYSTEM "a661.dtd"> <a661_df library_version="0" supp_version="2"> <model> <prop name="ApplicationId" value="1"/> </model> <a661_layer> <model> <prop name="LayerId" value="5"/> <prop name="ContextNumber" value="23"/> <prop name="Height" value="10000"/> <prop name="Width" value="10000"/> </model> <a661_widget name="SamplePanel" type="A661_PANEL"> <model> <prop name="WidgetIdent" value="1"/> <prop name="Enable" value="A661_TRUE" /> <prop name="Visible" value="A661_TRUE" /> <prop name="PosX" value="0"/> <prop name="PosY" value="0"/> <prop name="SizeX" value="10000"/> <prop name="SizeY" value="10000"/> <prop name="StyleSet" value="STYLESET_DEFAULT" /> </model> <a661_widget name="Hello World Label" type="A661_LABEL"> <model> <prop name="WidgetIdent" value="2"/> <prop name="Anonymous" value="A661_FALSE" /> <prop name="Visible" value="A661_TRUE" /> <prop name="PosX" value="5000" /> <prop name="PosY" value="5000" /> <prop name="SizeX" value="1500" /> <prop name="SizeY" value="1000" /> <prop name="RotationAngle" value="0.0" /> <prop name="StyleSet" value="0" /> <prop name="MaxStringLength" value="20" /> <prop name="MotionAllowed" value="A661_TRUE" /> <prop name="Font" value="T4" /> <prop name="ColorIndex" value="black" /> <prop name="Alignment" value="A661_CENTER" /> <prop name="LabelString" value="Hello World!" /> </model> </a661_widget> </a661_widget> </a661_layer> </a661_df>
Development and tools support편집
ARINC 661 GUI development includes tools for the specification of definition files and the kernel that use these files:
- Thanks to ARINC 661 concepts, the specification tools have no dependency on the execution platform,
- The kernel itself depends on the execution platform.
COTS specification tools for DF specification currently include SCADE Solutions for ARINC 661 Compliant Systems, DiSTI's GL Studio ARINC 661 Toolkit and Presagis VAPS XT 661 Toolkit.
Esterel Technologies announced on October 13, 2010, the availability of SCADE Solutions for ARINC 661 in 2011. SCADE Solutions for ARINC 661 allow creating both ARINC 661-compliant CDS and UA. For CDS developers, the toolchain features a complete customizable ARINC 661 compliant model-based widgets library and the automated generation of a portable ARINC 661 server, compliant with the DO-178B/C safety objectives up to level A. For UA developers, the toolchain features the model-based design and generation of DFs and the automatic generation of communication code between SCADE Suite UA models and the ARINC 661 Server.
The GL Studio ARINC 661 Toolkit is a plug-in to GL Studio HMI Toolkit that delivers a set of pre-existing customizable widgets, a DF Generator, CDS, Communication Libraries, and a User Application Generator.
Presagis  introduced the first COTS ARINC 661 development tool which allows creation of Widgets, Layers, DF Generation and embeddable real-time COTS CDS kernel with DO-178B/C certification artifacts  It must also be noted that because of the burden of Avionics software certification, the kernel must be embedded in a DO-178B-compliant environment.
- “Cockpit Display Systems (CDS) Subcommittee”. AEEC. 2007년 6월 14일. 2007년 6월 11일에 보존된 문서. 2007년 6월 16일에 확인함.
- Adams, Charlotte (2003년 3월 1일). “A380 Innovations: A Balancing Act”. aviationtoday.com. 2007년 6월 30일에 보존된 문서. 2007년 6월 16일에 확인함.
- Adams, Charlotte (2003년 7월 1일). “Airbus A400M”. aviationtoday.com. 2007년 6월 16일에 확인함.
- Jensen, David (2005년 11월 1일). “B787 Cockpit: Boeing’s Bold Move”. aviationtoday.com. 2007년 6월 16일에 확인함.
- “AgustaWestland Selects Presagis’s Next-Generation VAPS XT 661 Tool to Fly Aboard Its Aircraft”. airframer.com. 2006년 6월 10일. 2009년 7월 25일에 확인함.
- “Barco wins major contract under Royal Navy Merlin upgrade program”. Barco NV. 2007년 6월 18일. 2009년 1월 3일에 확인함.
- “AgustaWestland Accelerates Merlin HMI TouchScreen display software development with COTS ARINC 661 prototyping tools”. presagis.com. 2009년 6월 1일. 2010년 7월 25일에 확인함.
- “Helicopter HMIs: Managing risk with automatic code generation, standards, and simulation”. mil-embedded.com. September 2008. 2010년 7월 25일에 확인함.
- “Embraer selects SCADE Solutions for ARINC 661 from Esterel for cockpit display development”. militaryaerospace.com. 2011년 3월 17일. 2011년 5월 6일에 확인함.
- The standard also specifies an XML format for the UI language, but it is mainly used to ease DF production by specification tools. The kernel is initialized with the binary version of DFs
- “Esterel Technologies Introduces SCADE ARINC 661 Solutions for Interactive Cockpit Displays Development”. Esterel Technologies. 2010년 10월 13일. 2010년 11월 21일에 보존된 문서. 2010년 11월 7일에 확인함.
- “Understanding ARINC 661 and the benefits of 661-based development tools”. Presagis. 2010년 11월 7일에 확인함.