VuforiaWebService.Api.Core
3.0.0
dotnet add package VuforiaWebService.Api.Core --version 3.0.0
NuGet\Install-Package VuforiaWebService.Api.Core -Version 3.0.0
<PackageReference Include="VuforiaWebService.Api.Core" Version="3.0.0" />
paket add VuforiaWebService.Api.Core --version 3.0.0
#r "nuget: VuforiaWebService.Api.Core, 3.0.0"
// Install VuforiaWebService.Api.Core as a Cake Addin #addin nuget:?package=VuforiaWebService.Api.Core&version=3.0.0 // Install VuforiaWebService.Api.Core as a Cake Tool #tool nuget:?package=VuforiaWebService.Api.Core&version=3.0.0
Vuforia Web Service API Client
Overview
This repository contains a C# client for interacting with the Vuforia Web Service API. The client provides methods for managing targets within a Vuforia database, allowing for actions such as listing targets, retrieving reports, and managing target data.
Features
- Authentication: Utilize
ServerAccessKeys
for secure access to the Vuforia API. - Manage Targets: List, retrieve, update, and delete targets from the Vuforia database.
- Database Reports: Obtain summary reports for the database and target summaries.
- Similarity Check: Check for similar targets in the database.
Getting Started
Prerequisites
- .NET SDK installed on your machine.
- A Vuforia account with API access to retrieve your access and secret keys.
Installation
To use VuforiaWebService
in your project, install it via NuGet:
dotnet add package VuforiaWebService.Api.Core
dotnet add package VuforiaWebService.Api.Auth
dotnet add package VuforiaWebService.Api.Target
Alternatively, you can clone this repository and build the project locally:
git clone https://github.com/gachris/VuforiaWebService.git
cd VuforiaWebService
dotnet build
Usage
Run the Main
method to execute various operations against the Vuforia Web Service API. The sample code demonstrates how to:
- List All Targets: Retrieve a list of all targets in the database.
- Retrieve Specific Target: Get detailed information about a specific target based on its ID.
- Insert New Target: Add a new target to the database, including its properties such as name, width, and associated image.
- Update Existing Target: Modify the properties of an existing target identified by its ID.
- Delete Target: Remove a target from the database using its ID.
- Check Similar Targets: Identify targets that are similar to a specified target based on certain criteria.
- Get Target Summary Report: Retrieve a summary report for a specific target to gain insights into its details and performance.
- Get Database Summary Report: Get an overview report for the entire database, including statistics and status.
Example
Here is a simplified version of the Main
method demonstrating how to use the API client:
private static void Main()
{
try
{
var userCredential = new UserCredential();
var initializer = new BaseClientService.Initializer()
{
ApplicationName = "VuforiaWebService",
HttpClientInitializer = userCredential,
};
var keys = new ServerAccessKeys("YOUR_ACCESS_KEY", "YOUR_SECRET_KEY");
var targetService = new TargetService(initializer);
// Example: List all targets
var vuforiaGetAllResponse = targetService.TargetList.List(keys).Execute();
Console.WriteLine("All Targets:");
foreach (var target in vuforiaGetAllResponse.Results)
{
Console.WriteLine($"- ID: {target}");
}
// Example: Check for a specific target
var vuforiaRetrieveResponse = targetService.TargetList.Get(keys, "<your_target_id>").Execute();
Console.WriteLine("Target:");
Console.WriteLine($"- Name: {vuforiaRetrieveResponse.TargetRecord.Name}");
// Example: Insert a new target
var newTarget = targetService.TargetList.Insert(keys, new PostTrackableRequest
{
Name = "NewSampleTarget",
Width = 1,
Image = "<path_to_your_image>",
ActiveFlag = true
}).Execute();
Console.WriteLine($"Inserted New Target ID: {newTarget.TargetId}");
// Example: Update an existing target
var updatedTarget = targetService.TargetList.Update(keys, new UpdateTrackableRequest
{
Name = "UpdatedSampleTarget",
Width = 2
}, "<your_target_id>").Execute();
Console.WriteLine($"Target updated successfully.");
// Example: Delete a target
targetService.TargetList.Delete(keys, "<your_target_id>").Execute();
Console.WriteLine("Target deleted successfully.");
// Example: Check for similar targets
var similarTargetsResponse = targetService.TargetList.CheckSimilar(keys, "<your_target_id>").Execute();
Console.WriteLine("Similar Targets:");
foreach (var similarTarget in similarTargetsResponse.SimilarTargets)
{
Console.WriteLine($"- ID: {similarTarget}");
}
// Example: Get target summary report
var vuforiaRetrieveTargetSummaryReportResponse = targetService.TargetList.RetrieveTargetSummaryReport(keys, "<your_target_id>").Execute();
Console.WriteLine("Target Summary Report:");
Console.WriteLine($"- Database Name: {vuforiaRetrieveTargetSummaryReportResponse.DatabaseName}");
// Example: Get database summary report
var vuforiaGetDatabaseSummaryReportResponse = targetService.TargetList.GetDatabaseSummaryReport(keys).Execute();
Console.WriteLine("Database Summary Report:");
Console.WriteLine($"- Database Name: {vuforiaGetDatabaseSummaryReportResponse.Name}");
}
catch (VuforiaPortalApiException ex)
{
Console.WriteLine($"Vuforia API Error: {ex.Message} (Code: {ex.Error.ResultCode})");
}
catch (Exception ex)
{
Console.WriteLine($"General Error: {ex.Message}");
}
}
Exception Handling
The client includes error handling for API exceptions. You can catch VuforiaPortalApiException
to handle specific Vuforia API errors.
Contributing
Contributions are welcome! Please follow these steps if you wish to contribute:
- Fork the repository.
- Create a new branch for your feature or bugfix.
- Write clean, readable code and add comments where necessary.
- Submit a pull request.
License
This project is licensed under the MIT License. See the LICENSE file for more details.
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 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. |
.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 is compatible. |
.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
- Newtonsoft.Json (>= 13.0.1)
-
.NETStandard 2.1
- Newtonsoft.Json (>= 13.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on VuforiaWebService.Api.Core:
Package | Downloads |
---|---|
VuforiaWebService.Api.Auth
The Vuforia Web Services (VWS) API is a RESTful web API that enables developers to use their own Content Management System (CMS) with Vuforia’s Cloud Recognition service and VuMark Generation API |
GitHub repositories
This package is not used by any popular GitHub repositories.