What's new in QuickOPC 2020.3
From OPC Labs Knowledge Base
See also: Versions; Previous version: What's new in QuickOPC 2020.2
Internal version number: 5.59
Key changes:
- Usability improvements
Technology
- Updated to BoxedApp SDK 2020.2.
Licensing
- Improved the licensing error messages. Besides more precise wording, the typical messages now contain the list of (serial numbers of) licenses that were considered but dropped, together with their "release date covered" field, which is frequently the cause for the license not being recognized.
- Added text to License Manager dialog, explaining that licenses with Active status are not necessarily valid, depending on the particular combination of the component and environment status, and that the capabilities of the component itself should be used to check the license validity.
Packaging
- Added a new assembly OpcLabs.DotProlog to the product. It is needed whenever you use OpcLabs.BaseLibForms or OpcLabs.EasyOpcForms assemblies, but it does not need to be referenced in your project.
- Modified the NuGet manifest so that under .NET Framework, the packages for .NET Standard are not unnecessarily considered as dependencies.
- Fixed the version in dependency on Microsoft Visual C++ Redistributables. The proper dependency is "Microsoft Visual C++ Redistributable for Visual Studio 2015, 2017 and 2019", from https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads .
Installation and Uninstallation
- The setup log file now includes product version and build number information.
Component Improvements
- Input arguments that are materialized sequences (such as arrays, collections and lists) are now consistently checked for nullness of their elements before a method body is executed. That is, if the developer mistakenly passes in a sequence with a null element into an argument where it is not allowed, an ArgumentNullException exception will always be thrown upon method entry, and with an improved error text indicating the position (index) of the offending element.
OPC Classic
- Added method IEasyDAClient.GetItemSubscriptionArguments. This method allows the developer to obtain the arguments used to make an item subscription.
- Added method IEasyAEClient.GetEventsSubscriptionArguments. This method allows the developer to obtain the arguments used to make events subscription.
- Added an overload of IEasyDAClient.ChangeItemSubscription extension method, with an argument of type DAHandleGroupArguments.
- Added explicit conversion operator from DAVtqResult to ValueResult and their generic (typed) variants. Same functionality has the static DAVtqResult.ToValueResult method (for programming languages that do not support explicit conversion operators).
- Large OPC-DA requests are now "chunked", i.e. divided into smaller requests and performed sequentially. This is beneficial especially with Subscribe and Unsubscribe requests, because with many OPC servers, it allows the results be served to the client sooner. The behavior (chunk sizes, and whether the chunking will be applied to specific operation types at all) is configurable, and is managed by the new OPC-DA Optimizer plugin.
- Calls to OPC Read, Write and GetProperty operations that contain identical (except for the State property) arguments are now merged to perform just a single Read, Write or GetProperty (request merging). This behavior can be turned off in the OPC-DA Optimizer plugin parameters.
- Added (extension) method IEasyDAClient.WaitForMultipleItems. Subscribes to the specified OPC-DA items, and monitors their data until the predicates specified for each item become true, an error occurs, or the alloted time elapses.
- Added (extension) method IEasyDAClient.WaitForMultipleItemValues. Subscribes to the specified OPC-DA items, and monitors their data until they have at least the quality specified for each item, an error occurs, or the alloted time elapses.
- Added (extension) method IEasyDAClient.WaitForItemValue. Subscribes to the specified OPC-DA item, and monitors its data until it has "good" quality, an error occurs, or the alloted time elapses.
OPC UA
- Added HasServerTimestamp and HasSourceTimestamp properties to the UADataValue class (and therefore, also to the derived UAAttributeData and UADataSetFieldData classes). These properties determine whether there is a (non-default) server or source timestamp in the data value.
- Added method IEasyUAClient.IsKnownMonitoredItemSubscriptionHandle. Determines whether the given monitored item subscription handle is known to the given client.
OPC UA Client-Server
- Added TestEndpoint extension method on IEasyUAClient. The method tests whether an operational connection can be established to the specified endpoint of an OPC UA server.
- Added explicit conversion operator from UAAttributeDataResult to ValueResult and their generic (typed) variants. Same functionality has the static UAAttributeData.ToValueResult method (for programming languages that do not support explicit conversion operators).
- For consistency, renamed the Uri property in the ResourceDescriptor class to Url (in line with its UrlString property). All derived classes are of course also affected - including ServerDescriptor and UAEndpointDescriptor.
OPC UA PubSub
- Added method IEasyUASubscriber.IsKnownDataSetSubscriptionHandle. Determines whether the given data set subscription handle is known to the given subscriber.
- Added TestConnection and TestConnectionAsync methods on IEasyUASubscriber. The methods test whether an OPC UA PubSub connection can be successfully established.
- Added TestSubscription and TestSubscriptionAsync methods on IEasyUASubscriber. The methods test whether an OPC UA PubSub subscription can be successfully established.
- Factored out base UADataSetHeader class from the UADataSetData class. The UADataSetHeader can be used e.g. to distinguish dataset data that represent different datasets.
- Added Logicalize method to several PubSub objects (descriptors). The method removes the physical information from the object.
- Added AllowsResolution property to several PubSub objects (descriptors). The property determines whether the object has the necessary information to allow logical resolution..
- Added HasConfigurationVersion and HasTimestamp properties to the UADataSetHeader class.
- Added MajorVersionDateTimeLocal and MinorVersionDateTimeLocal properties to the UAConfigurationVersion class.
- Accompanied each string-typed XXXXUriString or XXXXUrlString property by a corresponding Uri-typed XXXXUri or XXXXUrl property (only in .NET, because the Uri class is not COM-visible).
- Based on UA Specification Errata 1.04, the UAPublisherId class no longer allows zero numeric identifiers, or empty string identifiers.
COM Components
- Added AddRange method to ElasticVector. Among other uses, it can be used in Xojo to convert a keyed collection to an elastic vector, and index its elements by integers, as a workaround for Xojo inability to enumerate the collections using COM interface method GetEnumerator.
- In COM-visible objects, consistently added SetXXXX methods to accompany each property setter whose argument is System.Object. This allows such properties be set from Visual Basic 6.0 with early binding.
- For COM tools (such as PHP) that do not allow to navigate between COM interfaces of an object, or provide an "amalgamated" set of members from multiple interfaces, when a specific interface is returned by a property or method, added InteropHelper object with the AsObject method. By passing the object through this method, the consuming COM tool is forced to use late binding, allowing the intended members be accessed.
- Added AsXXXXDataType methods to the _DataType COM interface, allowing the data type downcasting for tools like PHP.
- In order to allow passing 'null' to nullable array arguments from VBScript, consistently changed corresponding argument types in COM interfaces from "Type[]" to "object".
Component Refactorings
OPC Classic
- The IEasyDAClient.ReadMultipleItemValues and ReadItemValue (extension) methods no longer wait until a "non-bad" value becomes available. Instead, they simply perform a read, and an error is returned if the data do not contain valid value. The new behavior is consistent with corresponding methods in OPC UA, with method names better describing the internal working. This is potentially a breaking change (with some OPC servers). If you want the behavior similar to the past, use the new WaitForMultipleItemValues and WaitForItemValue (extension) methods, described at other place in this article.
- Moved EnableNativeClient, EnableNetApiClient (and EnableServiceClient, not yet functional) properties EasyDAClient and EasyDAClientConfiguration classes to EasyDASharedParameters class. Besides other advantages, this made them available for configuration in Connectivity Explorer and OpcCmd tools.
- Parameter bucketing has been reimplemented, and is now available as part of the OPC-DA Optimizer. The PercentDeadbandBucketsPerDecade and UpdateRateBucketsPerDecade properties have been moved to the DAParameterBucketingParameters class. The EasyDATopicParameters.ExactManualGroupMatch property has been removed; use DAOptimizerPluginParameters.EnableParameterBucketing property instead (note the negated semantics though).
- Item caching has been reimplemented, and is now available as part of the OPC-DA Optimizer. Item caching can be turned off using the DAOptimizerPluginParameters.EnableItemCaching property.
- Parameter restricting has been reimplemented, and is now available as part of the OPC-DA Optimizer. The related properties have been moved to the DAParameterRestrictingParameters class, and renamed to: FastestUpdateRate, SlowestUpdateRate, LowestPercentDadband, HighestPercentDadband.
- Removed properties: EasyDAEngineParameters.ClientLruSize, EasyDAEngineParameters.TopicLruSize, EasyAEEngineParameters.ClientLruSize.
- Subscription blending has been reimplemented, and is now available as part of the OPC-DA Optimizer. Subscription blending can be turned off using the DAOptimizerPluginParameters.EnableSubscriptionBlending property.
- Various optimizations (performed by OPC-DA Optimizer) are now done on a specific EasyDAClient instance, and are not shared (global). In applications that currently use separate EasyDAClient instances and can benefit from sharing some optimizations (such as Subscription Blending or Item Caching), consider using a common EasyDAClient instance.
User Interface
- Added "Server Connection Test" command to context menu on OPC UA endpoint nodes in browsing controls and dialogs. The commands attempts to make a connection to the OPC UA server using the selected endpoint, and displays the outcome. This affects user interface displayed by tools (such as in Live Mapping, or in Connection Explorer), and also the interface to the end user, such as through UAHostAndEndpointDialog, or UABrowseControl components.
Windows Forms Controls
- Added general AutomaticValueControl, which provides "control pages" for various objects, based on specified object type, and criteria such as whether the control should be nullable, polymorphic, or read-write.
- Control pages (usable by AutomaticValueControl) made available for following OPC UA PubSub configuration objects: UASubscribeDataSetArguments, UASubscribeDataSetFilter, UADataSetSubscriptionDescriptor, UAPubSubConnectionDescriptor, UASubscriberCommunicationParameters.
- Added specialized controls for several OPC UA PubSub objects: UAVersionTimeControl, UAFieldDataDictionaryControl, UADataSetHeaderControl and UADataSetDataControl.
Instrumentation
OPC Classic
- The EasyDAClient and EasyAEClient now have static LogEntry event, and the (non-static) LogEntry event on EasyDAClientConfiguration and EasyAEClientConfiguration is now functional. The semantics is analogous to the LogEntry event on EasyUAClient or EasyUAClientConfiguration. Currently, events related to licensing, callback errors and queue overflows are reported. When extended tracing is enabled, log entries appear in the generated trace.
Tools and Online Services
Connectivity Explorer
- Log entries from EasyDAClient now appear in "Event Records" view.
- Added Advanced tab to OPC-UA Attribute Point Subscribe Parameters editor. Allows the user to view and modify advanced monitoring parameters ("Queue size" and "Discard oldest") and subscription parameters ("Publishing interval" and "Priority").
- Added Edit tab to OPC-UA Attribute Point Read Parameters editor. Allows the user to view and modify the "Maximum age" and "Value only" parameters.
- Added Edit tab to OPC-UA Attribute Point Write Parameters editor. Allows the user to view and modify the "Value type code" and "Value only" parameters.
- Added Edit tab to OPC-DA Item Point Read Parameters editor. Allows the user to view and modify the "Data source", "Value age" and "Value only" parameters.
- Added Edit tab to OPC-DA Item Point Write Parameters editor. Allows the user to view and modify the "Value only" parameter.
Examples
- For better optimization, changed Web-based examples (C#, VB.NET) to use a shared client instance.
Platform: COM
- Retested the Xojo examples with Xojo 2019r3.1.
OPC Classic
- Added larger number of C# examples, showing e.g. how to browse access paths, browse branches, browse leaves, browse properties, browse servers, read item value with specifying server's CLSID, read multiple items "from device", do many reads repeatedly, perform synchronous OPC read, read multiple item values, unsubscribe all or multiple items, write an item (including timestamp and quality), list OPC categories that the server implements, and more.
- Added C# FormsDocExamples project, with examples for user interface (showing various browsing dialogs for OPC Classic), and added these C# examples to conceptual&reference documentation.
- Added call to TryEnableAutoSubscribingOptimization to (C#, VB.NET) Web-based examples, to show how to enable the auto-subscribing optimization.
OPC UA Client-Server
- Added a WPF port of OPC UA Demo Application: WpfEasyOpcUADemo. This new project is available both as a pre-built application that you can run after product install, and in source form in the C# examples solution.
- Added pair of examples UAWcfService1 and UAWcfClient1 (C#): A simple Web service using WCF technology. Provides a GetData method to read a value of an OPC UA variable. Accompanied by a console-based client code.
- Added example UAWindowsService1 (C#): A Windows Service that subscribes to variables from the OPC UA sample server, and logs their changes into a file.
- Added C# example that shows how to read value of server's NamespaceArray, and display the namespace URIs in it.
- Added C# example that shows how to write an ever-incrementing value to an OPC UA variable.
- Added C# UAFormsDocExamples project, with examples for user interface (showing various browsing dialogs for OPC UA), and added these C# examples to conceptual&reference documentation.
OPC UA PubSub
- Added Windows Forms demo application for OPC UA PubSub (EasyOpcUAPubSubDemo) in C#. Project source code is available in the Examples solution, and compiled version of the application is installed by the Setup program. The application offers a selection of ready-made settings for various OPC UA PubSub subscription choices, and also offers a rich user interface to specify custom settings. It then allows to subscribe to datasets and display the received data dynamically.
Documentation and Help
- Made clear at multiple places that Product Option licenses (such as Excel Option or StreamInsight Option) require base product license first.
- Improvements in the Best Practices section.
COM Components
- Documentation for all COM objects now consistently contains "Object Creation" section, with syntax for object creation in following languages or tools: C++, Free Pascal, JScript, Object Pascal (Delphi), Perl, PHP, PowerScript, Python, REALbasic (Xojo), Visual Basic (VB 6.), Visual FoxPro, VBA, VBScript, Xbase++.
- Added explanation of Xojo programming specifics, explaining how to use the ElasticVector for enumeration of keyed collections.