CanKit.Adapter.ControlCAN
0.5.4
dotnet add package CanKit.Adapter.ControlCAN --version 0.5.4
NuGet\Install-Package CanKit.Adapter.ControlCAN -Version 0.5.4
<PackageReference Include="CanKit.Adapter.ControlCAN" Version="0.5.4" />
<PackageVersion Include="CanKit.Adapter.ControlCAN" Version="0.5.4" />
<PackageReference Include="CanKit.Adapter.ControlCAN" />
paket add CanKit.Adapter.ControlCAN --version 0.5.4
#r "nuget: CanKit.Adapter.ControlCAN, 0.5.4"
#:package CanKit.Adapter.ControlCAN@0.5.4
#addin nuget:?package=CanKit.Adapter.ControlCAN&version=0.5.4
#tool nuget:?package=CanKit.Adapter.ControlCAN&version=0.5.4
CanKit.Adapter.ControlCAN
用于 CanKit 的 ControlCAN 适配器。通过 ControlCAN.dll 为使用 ControlCAN API 的设备(例如 GCAN/广成、CHX/创芯、ZLG/周立功 等)提供统一的 .NET API。
- 包:
CanKit.Adapter.ControlCAN - 依赖:
CanKit.Core
系统要求
- 需要在 Windows 上安装厂商提供的 ControlCAN 运行时(
ControlCAN.dll)。 - 确保
ControlCAN.dll在系统 PATH 中,或与应用程序放在同一目录。 - 进程位数需与 DLL 匹配(x86/x64)。部分老设备只提供 32 位库;如不确定,请以 x86 为目标。
安装
dotnet add package CanKit.Core
dotnet add package CanKit.Adapter.ControlCAN
端点格式
controlcan://USBCAN2?index=0#ch1controlcan://VCI_USBCAN2?index=0#ch1controlcan://?type=USBCAN2&index=0#ch1
说明
index选择设备索引(从 0 开始)。#chX选择通道索引(例如#ch0、#ch1)。type映射到 ControlCAN 的设备类型。若省略,默认USBCAN2。
快速上手
using CanKit.Core;
using CanKit.Core.Definitions;
// 以 500 kbps(经典 CAN)打开 USBCAN2 设备索引 0 的通道 1
using var bus = CanBus.Open("controlcan://USBCAN2?index=0#ch1",
cfg => cfg.Baud(500_000));
// 发送
bus.Transmit(CanFrame.Classic(0x321, new byte[] { 0xAA, 0xBB }));
// 接收(带超时,单位:毫秒)
foreach (var rx in bus.Receive(1, 100))
{
var f = rx.CanFrame;
Console.WriteLine($"RX 0x{f.ID:X} dlc={f.Dlc}");
}
备注
- 仅支持经典 CAN;ControlCAN 适配器不支持 CAN FD。
- 硬件过滤为基于掩码。若需按 ID 区间过滤,请启用软件兜底并添加区间规则,例如:
using var bus = CanBus.Open("controlcan://USBCAN2?index=0#ch0", cfg =>
cfg.SoftwareFeaturesFallBack(CanFeature.RangeFilter)
.RangeFilter(0x100, 0x200));
- 不支持读取总线使用率(bus load)。
ErrorCounters()通过VCI_ReadErrInfo读取;可用性和准确性可能因设备/驱动而异。- 如需可调整轮询间隔:
cfg.Custom("PollingInterval", 10)(毫秒)。
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. 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 is compatible. 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. net8.0-windows7.0 is compatible. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- CanKit.Core (>= 0.5.4)
-
net8.0
- CanKit.Core (>= 0.5.4)
-
net8.0-windows7.0
- CanKit.Core (>= 0.5.4)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
## 0.5.4
### Added
* **`FaultOccurred`**: Introduced a new event for reporting unrecoverable faults.
* **`CanExceptionPolicy`**: Added a unified exception-handling policy to standardize how adapter/receive exceptions are classified and handled across the library.
### Changed
* **Remove unused duplicate adapter**: Removed the duplicated and unused `ZCAN_PCIE_CANFD_200U` entry/implementation.
### Fixed
* **`CancellationTokenSource` disposal**: Fixed an issue where some adapters could leak a `CancellationTokenSource` when `CanBus` was disposed or when the receive task stopped due to an exception.
* **Event handler isolation**: Fixed an issue where exceptions thrown inside `FrameReceive` / `ErrorOccurred` subscriber callbacks could stop the receive thread. Subscriber exceptions are now contained and do not terminate the receive loop.
### Performance
* None.
### Breaking changes
* None. (Only invalid conditions and subscriber callback exceptions are handled more defensively; normal operation is unchanged.)