Goxis is a library designed to facilitate the development of ACAP (Axis Camera Application Platform) applications for AXIS cameras.
This library includes user-friendly wrappers for most APIs provided by the native SDK.
Goxis organizes its functionality around several key areas of the native SDK, each encapsulated within its own package for ease of use:
- axevent - Event API for managing camera events.
- axoverlay - Overlay API, including support for Cairo, for drawing over video feeds.
- axparameter - Parameter API for managing camera parameters.
- axstorage - Edge Storage API for accessing and managing on-camera storage.
- axvdo - Video Capture API for handling video streams.
- axlarod - Larod API
- axlicense - License Key API for managing application licenses.
- axsyslog - Syslog for logging and diagnostics.
Beyond the core API wrappers, Goxis also provides several additional packages designed to speed up the development process and enhance application capabilities:
- acapapp - Offers a high-level abstraction for quick and efficient ACAP application development.
- axmanifest - Aids in loading and parsing manifest files, simplifying application configuration and setup.
- dbus - Provides helpers for interacting with the D-Bus interface, including retrieving VAPIX credentials.
- vapix - Facilitates the use of the VAPIX API for interacting with camera functionalities.
- glib - Includes helpers for working with GLib, such as managing the main event loop.
- Docker for building the ACAP applications
- goxisbuilder
go install github.com/Cacsjep/goxisbuilder@latest
goxisbuilder.exe -newapp
Located at this repo Examples
go get -u github.com/Cacsjep/goxis@latest
The AcapApplication
acts as a foundational abstraction layer designed to streamline the handling of common tasks such as syslog logging, managing the GObject main loop, and the manipulation of parameters and events.
Upon instantiation, AcapApplication
undertakes several crucial steps::
- Manifest Parsing: It reads the manifest file to extract the application's name.
- Parameter Management: Initializes an
axparameter
instance, enabling the application to get, set, and remove parameters efficiently. - Event Handling: Sets up an
axevent
handler to facilitate event processing. - GMain Loop Preparation: Configures a GMain loop complete with signal handlers, ensuring robust event management.
AcapApplication
offers access to a variety of powerful functionalities, such as::
- FrameProvider: Facilitates easy interaction with
axvdo
, streamlining video-related operations. - OverlayProvide: Facilitates easy interaction with
axoverlay
related operations. - StorageProvider: Offers straightforward access to the camera's storage, enhancing data management capabilities.
app.IsLicenseValid(major_version int, minor_version int)
: Verifies the validity of the application's license for the specified version.app.Run()
: Activates the GMain loop within the application, allowing for continuous operation.app.GetSnapshot(video_channel int)
: Captures and retrieves a JPEG snapshot from a given video channel.
and more ....
Just use goxisbuilder tool for streamlined builds.
.\goxisbuilder.exe -newapp
Most events are already declared in axevent
. If you miss something, you can manually craft it, create a PR, or just ask! 😊
You can use the AXIS get_eventlist.py
script (Native SDK Repo - AXIS) to get the XML list to see events that your device supports.
Tip
Use AXIS Meta Data Monitor to validate and determine if the desired event is triggered.
It is crucial to set the correct namespace for each topic. Incorrect namespaces can cause issues in axevent
C API mapping. Check carefully if multiple namespaces are involved, and ensure the correct setup.
When there is only one namespace for all entries, ensure consistency across all topics. In this example, all entries use OnfivNameSpaceTnsAxis
:
NewTopicKeyValueEntrie("topic0", &OnfivNameSpaceTnsAxis, "CameraApplicationPlatform"),
NewTopicKeyValueEntrie("topic1", &OnfivNameSpaceTnsAxis, "ObjectAnalytics"),
NewTopicKeyValueEntrie("topic2", &OnfivNameSpaceTnsAxis, "xinternal_data"),
When there are multiple namespaces, ensure subsequent entries after a path change use the correct namespace. For instance, VirtualPort
uses the tnsaxis
namespace:
NewTopicKeyValueEntrie("topic0", &OnfivNameSpaceTns1, "Device"),
NewTopicKeyValueEntrie("topic1", &OnfivNameSpaceTnsAxis, "IO"),
NewTopicKeyValueEntrie("topic2", &OnfivNameSpaceTnsAxis, "VirtualPort"),
// <tnsaxis:CameraApplicationPlatform>
// <ObjectAnalytics>
// <xinternal_data wstop:topic="true">
// <tt:MessageDescription IsProperty="false">
// <tt:Data>
// <tt:SimpleItemDescription Name="svgframe" Type="xsd:string"></tt:SimpleItemDescription>
// </tt:Data>
// </tt:MessageDescription>
// </xinternal_data>
// </ObjectAnalytics>
// </tnsaxis:CameraApplicationPlatform>
func CameraApplicationPlatformXInternalDataEventKvs(svgFrame *string) *AXEventKeyValueSet {
return NewAXEventKeyValueSetFromEntries([]KeyValueEntrie{
NewTopicKeyValueEntrie("topic0", &OnfivNameSpaceTnsAxis, "CameraApplicationPlatform"),
NewTopicKeyValueEntrie("topic1", &OnfivNameSpaceTnsAxis, "ObjectAnalytics"),
NewTopicKeyValueEntrie("topic2", &OnfivNameSpaceTnsAxis, "xinternal_data"),
NewStringKeyValueEntrie("svgframe", svgFrame),
})
}
type CameraApplicationPlatformXInternalDataEvent struct {
SvgFrame string `eventKey:"svgframe"`
}
Last Modified: 08.03.2024
Chip | Architecture |
---|---|
ARTPEC-6 | armv7hf |
ARTPEC-7 | armv7hf |
ARTPEC-8 | aarch64 |
CV25 | aarch64 |
i.MX 6SoloX | armv7hf |
i.MX 6ULL | armv7hf |
S5 | aarch64 |
S5L | aarch64 |
Mapping table for schema, firmware and SDK version.
It’s recommended to use the latest manifest version available for the minimum firmware version targeted.
Schema | Firmware | SDK | Description |
---|---|---|---|
1.0 | 10.7 | 1.0 | Initial basic version |
1.1 | 10.7 | 1.0 | Additional fields, mainly for technical reasons |
1.2 | 10.7 | 1.0 | Enables uninstall functionality which is required by e.g. docker-compose-acap |
1.3 | 10.9 | 1.1 | Architecture will be automatically generated and added to manifest at packaging step |
1.3.1 | 11.0 | 1.4 | Bugfixes; Allow = in runOptions and maxLength of appName should be 26 |
1.4.0 | 11.7 | 1.11 | Allow new characters ( ) , . ! ? & ' for vendor field |
1.5.0 | 11.8 | 1.12 | - Add support for reverse proxy configuration. - Add access policy for ACAP application web content. - Allow - character in secondary groups of linux resources. - Allow strings in requiredMethods and conditionalMethods under dbus to end with .* to match all methods of a D-Bus interface. |
1.6.0 | 11.9 | 1.13 | - Add support for characters $ and \ in apiPath of the reverse proxy configuration. - Add optional field $schema that can point out a manifest schema to use for manifest validation and auto-completion. - Allow strings in requiredMethods and conditionalMethods under dbus to contain -. |
Choose the appropriate SDK version based on what firmware version you want supporting your ACAP application.
SDK version | Compatible with firmware version |
---|---|
SDK 3.0 | 9.70 and later |
SDK 3.1 | 9.80 (LTS) and later |
SDK 3.2 | 10.2 and later |
SDK 3.3 | 10.5 and later |
SDK 3.4 | 10.6 and later |
SDK 3.5 | 10.9 and later |
ACAP Release vs ACAP Native SDK Image version vs. Compatible with AXIS OS version
ACAP Release | ACAP Native SDK Image version | Compatible with AXIS OS version |
---|---|---|
4.0 | 1.0 | 10.7 and later until LTS |
4.1 | 1.1 | 10.9 and later until LTS |
4.2 | 1.2 | 10.10 and later until LTS |
4.3 | 1.3 | 10.12 (LTS) |
4.4 | 1.4 | 11.0 and later until LTS |
4.5 | 1.5 | 11.1 and later until LTS |
4.6 | 1.6 | 11.2 and later until LTS |
4.7 | 1.7 | 11.3 and later until LTS |
4.8 | 1.8 | 11.4 and later until LTS |
4.9 | 1.9 | 11.5 and later until LTS |
4.10 | 1.10 | 11.6 and later until LTS |
4.11 | 1.11 | 11.7 and later until LTS |
4.12 | 1.12 | 11.8 and later until LTS |
4.13 | 1.13 | 11.9 and later until LTS |