OpcDaNetCore 1.0.2
See the version list below for details.
dotnet add package OpcDaNetCore --version 1.0.2
NuGet\Install-Package OpcDaNetCore -Version 1.0.2
<PackageReference Include="OpcDaNetCore" Version="1.0.2" />
paket add OpcDaNetCore --version 1.0.2
#r "nuget: OpcDaNetCore, 1.0.2"
// Install OpcDaNetCore as a Cake Addin #addin nuget:?package=OpcDaNetCore&version=1.0.2 // Install OpcDaNetCore as a Cake Tool #tool nuget:?package=OpcDaNetCore&version=1.0.2
Opc Da for .NET
This package allows you to use the OPC DA protocol in .Net applications.
NOTE: The OPC DA is only supported in Windows platforms.
Installation
You can install this package with command:
dotnet add package OpcDaNetCore
Use
Find servers
You can find available servers by specifying the ip address:
var servers = await BrowseOpcDaServers.BrowseServersAsync("localhost");
Build a Service
You can build an OPC DA service using the selected server from previous method:
ServerHost host = servers.FirstOrDefault();
using var server = await new OpcDaFactory()
.WithServer(host)
.BuildAsync();
Or you can add server specifications manually:
using var server = await new OpcDaFactory()
.WithIp("localhost")
.WithServerName("Kepware.KEPServerEX.V5")
.BuildAsync();
You can browse nodes:
var browse = await server.BrowseNodeAsync(null);
foreach (var browseElement in browse)
{
Console.WriteLine($"{browseElement.Name}; {browseElement.Id}; Has children: {browseElement.HasChildren}");
}
var node = browse.FirstOrDefault()?.Id;
browse = await server.BrowseNodeAsync(node);
foreach (var browseElement in browse)
{
Console.WriteLine($"{browseElement.Name}; {browseElement.Id}; Has children: {browseElement.HasChildren}");
}
You can add items to a group. If the group does not exists, then will be created:
server.AddItems("Group 1", "Simulation Examples.Functions.Ramp2", "Simulation Examples.Functions.Ramp3");
You can remove items from a group:
server.RemoveItems("Group 1", "Simulation Examples.Functions.Ramp2", "Simulation Examples.Functions.Ramp3");
You can read all items in a group:
var read = server.Read("Group 1");
foreach (var readElement in read)
{
Console.WriteLine($"{readElement.ItemName} - {readElement.Value}");
}
Or read specific items. In this method you can read any item available in the server, not just items from a specific group, but must specify a group:
var readAny = server.Read("Group 1", "Simulation Examples.Functions.Ramp1", "Simulation Examples.Functions.Sine1");
foreach (var readElement in readAny)
{
Console.WriteLine($"{readElement.ItemName} - {readElement.Value}");
}
You can write into tags:
var valueToWrite1 = new ItemDataValue("Channel1.Device1.Tag2", 125);
var valueToWrite2 = new ItemDataValue("Channel1.Device1.Tag3", 126);
server.Write("Group 1",valueToWrite1, valueToWrite2);
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net7.0
- Quick.OpcNetApi (>= 2.1.108)
- Quick.OpcNetApi.Com (>= 2.1.108)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.