Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 002d24e2b0 | |||
| bd6cff81ec | |||
| a52e1a27fc | |||
| 4fa9ce6131 | |||
| c36505d530 | |||
| 167dd8be77 | |||
| 77a3e37a0e | |||
| 1c13ef429c |
7
.dockerignore
Normal file
7
.dockerignore
Normal file
@@ -0,0 +1,7 @@
|
||||
/.idea
|
||||
/.git
|
||||
/cmake-build-debug-visual-studio
|
||||
/V6.1.9.45_build20220902_ArmLinux64_ZH_20240802154010_lib.zip
|
||||
/V6.1.9.48_build20230410_linux64_20240829112751_lib.zip
|
||||
/V6.1.9.48_build20230410_win64_20240829112623_lib.zip
|
||||
/build
|
||||
7
.gitignore
vendored
7
.gitignore
vendored
@@ -1,7 +1,14 @@
|
||||
/.idea
|
||||
/.cache
|
||||
/.fleet
|
||||
/cmake-build-debug-visual-studio
|
||||
/cmake-build-release-visual-studio
|
||||
*.lib
|
||||
*.dll
|
||||
*.so
|
||||
*.a
|
||||
*.zip
|
||||
/build
|
||||
/arm64_linux_lib
|
||||
/arm64_windows_lib
|
||||
/amd64_linux_lib
|
||||
@@ -1,9 +1,27 @@
|
||||
cmake_minimum_required(VERSION 3.29)
|
||||
project(HikNetSDKPkg)
|
||||
cmake_minimum_required(VERSION 3.15)
|
||||
|
||||
project(HikNetSDKPkg CXX)
|
||||
set(CMAKE_CXX_STANDARD 11)
|
||||
include_directories("./src/include/Hik/amd64")
|
||||
add_compile_definitions(Export)
|
||||
|
||||
set(OS ${CMAKE_HOST_SYSTEM_NAME})
|
||||
set(Arch ${CMAKE_HOST_SYSTEM_PROCESSOR})
|
||||
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/build)
|
||||
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/build)
|
||||
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/build)
|
||||
|
||||
message(STATUS "Target Operating System: ${OS}")
|
||||
message(STATUS "Target Architecture: ${Arch}")
|
||||
|
||||
if(OS STREQUAL "Windows")
|
||||
set(CMAKE_DEBUG_POSTFIX "_win_amd64_d")
|
||||
set(CMAKE_RELEASE_POSTFIX "_win_amd64")
|
||||
elseif (Arch STREQUAL "x86_64" OR Arch STREQUAL "amd64")
|
||||
set(CMAKE_DEBUG_POSTFIX "_linux_amd64_d")
|
||||
set(CMAKE_RELEASE_POSTFIX "_linux_amd64")
|
||||
elseif (Arch STREQUAL "aarch64" OR Arch STREQUAL "arm64")
|
||||
set(CMAKE_DEBUG_POSTFIX "_linux_arm64_d")
|
||||
set(CMAKE_RELEASE_POSTFIX "_linux_arm64")
|
||||
endif ()
|
||||
|
||||
add_library(HikNetSDKPkg SHARED
|
||||
library.cpp
|
||||
@@ -13,8 +31,34 @@ add_library(HikNetSDKPkg SHARED
|
||||
src/FormatTrans.cpp
|
||||
)
|
||||
|
||||
target_compile_definitions(HikNetSDKPkg PRIVATE Export)
|
||||
|
||||
target_link_directories(HikNetSDKPkg PUBLIC ./HCNetSDKamd64/lib)
|
||||
target_link_libraries(HikNetSDKPkg "HCNetSDK.lib")
|
||||
target_link_libraries(HikNetSDKPkg "HCCore.lib")
|
||||
target_link_libraries(HikNetSDKPkg "GdiPlus.lib")
|
||||
if(Arch STREQUAL "x86_64" OR OS STREQUAL "Windows")
|
||||
target_include_directories(HikNetSDKPkg PRIVATE "./src/include/Hik/amd64")
|
||||
elseif (Arch STREQUAL "aarch64")
|
||||
target_include_directories(HikNetSDKPkg PRIVATE "./src/include/Hik/arm64")
|
||||
endif ()
|
||||
|
||||
if(OS STREQUAL "Windows")
|
||||
target_link_directories(HikNetSDKPkg PRIVATE "./arm64_windows_lib")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "HCNetSDK.lib")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "HCCore.lib")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "GdiPlus.lib")
|
||||
elseif (Arch STREQUAL "x86_64" OR Arch STREQUAL "amd64")
|
||||
target_link_directories(HikNetSDKPkg PRIVATE "./amd64_linux_lib")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libHCCore.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libhcnetsdk.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libhpr.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libz.so")
|
||||
elseif (Arch STREQUAL "aarch64")
|
||||
target_link_directories(HikNetSDKPkg PRIVATE "./arm64_linux_lib")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libAudioRender.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libcrypto.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libHCCore.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libhcnetsdk.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libhpr.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libPlayCtrl.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libssl.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libSuperRender.so")
|
||||
target_link_libraries(HikNetSDKPkg PRIVATE "libz.so")
|
||||
endif ()
|
||||
22
Dockerfile
Normal file
22
Dockerfile
Normal file
@@ -0,0 +1,22 @@
|
||||
FROM alpine:3.19 AS deps
|
||||
|
||||
WORKDIR /usr
|
||||
|
||||
RUN apk add gcc g++ cmake make acl
|
||||
|
||||
FROM alpine:3.19 AS build
|
||||
|
||||
WORKDIR /hikbuild
|
||||
|
||||
COPY --from=deps /usr /usr
|
||||
COPY --from=deps /lib /lib
|
||||
COPY . /hikbuild
|
||||
|
||||
RUN cmake . -D Arch=${TARGETARCH} -D CMAKE_BUILD_TYPE=RELEASE && make
|
||||
|
||||
FROM alpine:3.19 AS export
|
||||
|
||||
WORKDIR /home
|
||||
COPY --from=build /hikbuild/build /home
|
||||
|
||||
#docker buildx build --platform linux/amd64,linux/arm64 --output type=local,dest=/hikbuild/ .
|
||||
113
Hikvision.go
113
Hikvision.go
@@ -1,4 +1,4 @@
|
||||
package main
|
||||
package HikNetSDK
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
@@ -51,9 +51,13 @@ func init() {
|
||||
func getSystemLibrary() string {
|
||||
switch runtime.GOOS {
|
||||
case "linux":
|
||||
return "libc.so.6"
|
||||
if runtime.GOARCH == "amd64" || runtime.GOARCH == "386" {
|
||||
return "libHikNetSDKPkg_linux_amd64.so"
|
||||
} else {
|
||||
return " libHikNetSDKPkg_linux_arm64.so"
|
||||
}
|
||||
case "windows":
|
||||
return "Hikvision_Network_SDK_Packaging_Library.dll"
|
||||
return "HikNetSDKPkg_win_amd64.dll"
|
||||
default:
|
||||
panic(fmt.Errorf("GOOS=%s is not supported", runtime.GOOS))
|
||||
}
|
||||
@@ -61,16 +65,18 @@ func getSystemLibrary() string {
|
||||
|
||||
type HIKBallCamera struct {
|
||||
core unsafe.Pointer
|
||||
BallCameraCfg BallCamera
|
||||
}
|
||||
|
||||
func NewHIKBallCamera() *HIKBallCamera {
|
||||
func NewHIKBallCamera(BallCameraCfg BallCamera) *HIKBallCamera {
|
||||
return &HIKBallCamera{
|
||||
core: newHIKBallCamera(),
|
||||
BallCameraCfg: BallCameraCfg,
|
||||
}
|
||||
}
|
||||
|
||||
func (h *HIKBallCamera) Login(ip string, port string, username string, password string, BallMachineType string) bool {
|
||||
return initBallCamera(h.core, ip, port, username, password, BallMachineType)
|
||||
func (h *HIKBallCamera) Login() bool {
|
||||
return initBallCamera(h.core, h.BallCameraCfg.Ip, h.BallCameraCfg.Port, h.BallCameraCfg.User, h.BallCameraCfg.Password, h.BallCameraCfg.Type)
|
||||
}
|
||||
func (h *HIKBallCamera) PtzTo(Action int, P, T, Z float32) bool {
|
||||
return ptzTo(h.core, Action, P, T, Z)
|
||||
@@ -87,16 +93,18 @@ func (h *HIKBallCamera) StartBus(Direction, Speed int) bool {
|
||||
|
||||
type HIKNvr struct {
|
||||
core unsafe.Pointer
|
||||
NvrConfig Nvr
|
||||
}
|
||||
|
||||
func NewHIKNvr() *HIKNvr {
|
||||
func NewHIKNvr(nvrConfig Nvr) *HIKNvr {
|
||||
return &HIKNvr{
|
||||
core: newHIKNvr(),
|
||||
NvrConfig: nvrConfig,
|
||||
}
|
||||
}
|
||||
|
||||
func (h *HIKNvr) Login(ip string, port string, username string, password string, nvrType int) bool {
|
||||
return initNvr(h.core, ip, port, username, password, nvrType)
|
||||
func (h *HIKNvr) Login() bool {
|
||||
return initNvr(h.core, h.NvrConfig.Ip, h.NvrConfig.Port, h.NvrConfig.User, h.NvrConfig.Password, h.NvrConfig.Channel)
|
||||
}
|
||||
|
||||
func (h *HIKNvr) CheckTimeRegionWithMonth(year int, month int) string {
|
||||
@@ -105,3 +113,90 @@ func (h *HIKNvr) CheckTimeRegionWithMonth(year int, month int) string {
|
||||
func (h *HIKNvr) CheckTimeRegionWithDay(year int, month int, day int) string {
|
||||
return checkTimeRegionWithDay(h.core, year, month, day)
|
||||
}
|
||||
|
||||
func (h *HIKBallCamera) WarpingPtByHomography(matrix []float64, p Point) Point {
|
||||
var x, y, z float64
|
||||
x = matrix[0]*p.X + matrix[1]*p.Y + 1.*matrix[2]
|
||||
y = matrix[3]*p.X + matrix[4]*p.Y + 1.*matrix[5]
|
||||
z = matrix[6]*p.X + matrix[7]*p.Y + 1.*matrix[8]
|
||||
|
||||
x /= z
|
||||
y /= z
|
||||
return Point{X: x, Y: y}
|
||||
}
|
||||
|
||||
func (h *HIKBallCamera) mapping(startV float64, max float64, value float64, direction string, method string) float64 {
|
||||
if direction == "+" {
|
||||
if method == "inv" {
|
||||
if value > (max - startV) {
|
||||
return value - (max - startV)
|
||||
} else {
|
||||
return startV + value // 映射
|
||||
}
|
||||
} else {
|
||||
if value > startV {
|
||||
return value - startV
|
||||
} else {
|
||||
return (max - startV) + value // 映射
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if value > startV {
|
||||
return startV + max - value
|
||||
} else {
|
||||
return startV - value
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func (h *HIKBallCamera) OneClickToSeeInFullView(point Point) bool {
|
||||
TransPoint := h.WarpingPtByHomography(h.BallCameraCfg.Matrix.Matrix, point)
|
||||
return h.PtzTo(5,
|
||||
float32(h.mapping(h.BallCameraCfg.Matrix.PStart, h.BallCameraCfg.Matrix.PMax, TransPoint.X, h.BallCameraCfg.Matrix.PPositiveDirection, "inv")),
|
||||
float32(h.mapping(h.BallCameraCfg.Matrix.TStart, h.BallCameraCfg.Matrix.TMax, TransPoint.Y, h.BallCameraCfg.Matrix.TPositiveDirection, "inv")),
|
||||
0.0,
|
||||
)
|
||||
}
|
||||
|
||||
func (h *HIKBallCamera) PTZ2FullView() (Point, error) {
|
||||
var ptz PTZ
|
||||
if !h.PTZGet(&ptz.P, &ptz.T, &ptz.Z) {
|
||||
return Point{}, fmt.Errorf("PTZ Get Error")
|
||||
}
|
||||
return h.WarpingPtByHomography(h.BallCameraCfg.Matrix.InvMatrix, Point{
|
||||
X: h.mapping(h.BallCameraCfg.Matrix.PStart, h.BallCameraCfg.Matrix.PMax, float64(ptz.P), h.BallCameraCfg.Matrix.PPositiveDirection, ""),
|
||||
Y: h.mapping(h.BallCameraCfg.Matrix.TStart, h.BallCameraCfg.Matrix.TMax, float64(ptz.T), h.BallCameraCfg.Matrix.TPositiveDirection, "")}), nil
|
||||
}
|
||||
|
||||
func (hikBC *HIKBallCamera) Invert3x3() bool {
|
||||
|
||||
a := hikBC.BallCameraCfg.Matrix.Matrix[0]
|
||||
b := hikBC.BallCameraCfg.Matrix.Matrix[1]
|
||||
c := hikBC.BallCameraCfg.Matrix.Matrix[2]
|
||||
d := hikBC.BallCameraCfg.Matrix.Matrix[3]
|
||||
e := hikBC.BallCameraCfg.Matrix.Matrix[4]
|
||||
f := hikBC.BallCameraCfg.Matrix.Matrix[5]
|
||||
g := hikBC.BallCameraCfg.Matrix.Matrix[6]
|
||||
h := hikBC.BallCameraCfg.Matrix.Matrix[7]
|
||||
i := hikBC.BallCameraCfg.Matrix.Matrix[8]
|
||||
|
||||
det := a*(e*i-f*h) - b*(d*i-f*g) + c*(d*h-e*g)
|
||||
|
||||
if det == 0 {
|
||||
return false
|
||||
}
|
||||
|
||||
invDet := 1.0 / det
|
||||
hikBC.BallCameraCfg.Matrix.InvMatrix = []float64{
|
||||
(e*i - f*h) * invDet,
|
||||
(c*h - b*i) * invDet,
|
||||
(b*f - c*e) * invDet,
|
||||
(f*g - d*i) * invDet,
|
||||
(a*i - c*g) * invDet,
|
||||
(c*d - a*f) * invDet,
|
||||
(d*h - e*g) * invDet,
|
||||
(b*g - a*h) * invDet,
|
||||
(a*e - b*d) * invDet,
|
||||
}
|
||||
return true
|
||||
}
|
||||
|
||||
28
README.md
Normal file
28
README.md
Normal file
@@ -0,0 +1,28 @@
|
||||
## 已验证系统环境
|
||||
|
||||
| 架构 | 系统 |使用docker |
|
||||
|:-------:|:-----------:|:-------:|
|
||||
| aarch64 | alpine:3.19 | 🐳 |
|
||||
| x86_64 | alpine:3.19 | 🐳 |
|
||||
| x86_64 | windows 10 | |
|
||||
|
||||
## 编译流程
|
||||
### 1. 下载库
|
||||
在仓库的发行版中 将 HikNetSDK 标签下的不同架构的 lib 放在源码根目录中
|
||||
```shell
|
||||
D:.
|
||||
│ V6.1.9.45_build20220902_ArmLinux64_ZH_20240802154010_lib.zip
|
||||
│ V6.1.9.48_build20230410_linux64_20240829112751_lib.zip
|
||||
│ V6.1.9.48_build20230410_win64_20240829112623_lib.zip
|
||||
```
|
||||
### 2.1 编译 Linux 部分
|
||||
将下载的zip压缩文件 `ArmLinux64` 和 `linux64` 在源码目录解压,然后重命名
|
||||
```shell
|
||||
V6.1.9.45···ArmLinux64···.zip --解压后重命名为--> arm64_linux_lib
|
||||
V6.1.9.48···linux64···.zip --解压后重命名为--> amd64_linux_lib
|
||||
```
|
||||
### 2.2 编译 Windows 部分
|
||||
将下载的zip压缩文件 `win64` 在源码目录解压,然后重命名
|
||||
```shell
|
||||
V6.1.9.45···win64···.zip --解压后重命名为--> arm64_windows_lib
|
||||
```
|
||||
72
Type.go
Normal file
72
Type.go
Normal file
@@ -0,0 +1,72 @@
|
||||
package HikNetSDK
|
||||
|
||||
import "encoding/json"
|
||||
|
||||
type HikCfg struct {
|
||||
Nvr map[string]Nvr `json:"Nvr"`
|
||||
BallCamera map[string]BallCamera `json:"BallCamera"`
|
||||
}
|
||||
|
||||
type Nvr struct {
|
||||
Name string `json:"Name"`
|
||||
Ip string `json:"Ip"`
|
||||
Port string `json:"Port"`
|
||||
User string `json:"User"`
|
||||
Password string `json:"Password"`
|
||||
Channel int `json:"Channel"`
|
||||
}
|
||||
|
||||
type BallCamera struct {
|
||||
Type string `json:"Type"`
|
||||
Name string `json:"Name"`
|
||||
Ip string `json:"Ip"`
|
||||
Port string `json:"Port"`
|
||||
User string `json:"User"`
|
||||
Password string `json:"Password"`
|
||||
RtspUrl string `json:"RtspUrl"`
|
||||
Matrix Matrix `json:"Matrix"`
|
||||
Channel int `json:"Channel"`
|
||||
}
|
||||
|
||||
type Matrix struct {
|
||||
PStart float64 `json:"P_Start"`
|
||||
PMax float64 `json:"P_Max"`
|
||||
PPositiveDirection string `json:"p_Positive_Direction"`
|
||||
TStart float64 `json:"T_Start"`
|
||||
TMax float64 `json:"T_Max"`
|
||||
TPositiveDirection string `json:"T_Positive_Direction"`
|
||||
Matrix []float64 `json:"Matrix"`
|
||||
InvMatrix []float64 `json:"InvMatrix"`
|
||||
PointSet map[string]PointPair `json:"PointSet"`
|
||||
}
|
||||
|
||||
type PointPair struct {
|
||||
X float64 `json:"X"`
|
||||
Y float64 `json:"Y"`
|
||||
P float64 `json:"P"`
|
||||
T float64 `json:"T"`
|
||||
}
|
||||
|
||||
|
||||
type PTZ struct {
|
||||
P float32 `json:"P"`
|
||||
T float32 `json:"T"`
|
||||
Z float32 `json:"Z"`
|
||||
}
|
||||
|
||||
type MoveCfg struct {
|
||||
Speed int `json:"Speed"`
|
||||
Direction int `json:"Direction"`
|
||||
}
|
||||
type Point struct {
|
||||
X float64 `json:"X"`
|
||||
Y float64 `json:"Y"`
|
||||
}
|
||||
|
||||
func (h *HikCfg) Json() []byte {
|
||||
marshal, err := json.Marshal(h)
|
||||
if err != nil {
|
||||
return nil
|
||||
}
|
||||
return marshal
|
||||
}
|
||||
@@ -1,13 +1,18 @@
|
||||
#ifndef HIKVISION_NETWORK_SDK_PACKAGING_LIBRARY_LIBRARY_H
|
||||
#define HIKVISION_NETWORK_SDK_PACKAGING_LIBRARY_LIBRARY_H
|
||||
|
||||
#ifdef Export
|
||||
#define Omnimatrix __declspec(dllexport)
|
||||
#ifdef _WIN32
|
||||
#ifdef Export
|
||||
#define Omnimatrix __declspec(dllexport)
|
||||
#else
|
||||
#define Omnimatrix __declspec(dllimport)
|
||||
#endif
|
||||
#else
|
||||
#define Omnimatrix __declspec(dllimport)
|
||||
#define Omnimatrix
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
@@ -24,6 +29,7 @@ extern "C" {
|
||||
Omnimatrix bool InitNvr(void* PtrHIKNvr,char* ip, char* port, char* username, char* password, int channel);
|
||||
Omnimatrix char* CheckTimeRegionWithMonth(void* PtrHIKNvr,int year,int month);
|
||||
Omnimatrix char* CheckTimeRegionWithDay(void* PtrHIKNvr,int year,int month,int day);
|
||||
Omnimatrix int NvrUTCDiff();
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
||||
@@ -63,7 +63,7 @@ char* CheckTimeRegionWithMonth(void* PtrHIKNvr,int year,int month){
|
||||
res = HIKNvrObj->TimeToJson(select_time, &available_date_vec).dump();
|
||||
}
|
||||
char* cString = new char[res.size() + 1];
|
||||
strcpy_s(cString, res.size()+1,res.c_str());
|
||||
std::strcpy(cString,res.c_str());
|
||||
return cString;
|
||||
}
|
||||
|
||||
@@ -81,6 +81,11 @@ char* CheckTimeRegionWithDay(void* PtrHIKNvr,int year,int month,int day){
|
||||
res = HIKNvrObj->TimeToJsonInDay(select_time, &available_time_vec).dump();
|
||||
}
|
||||
char* cString = new char[res.size() + 1];
|
||||
strcpy_s(cString, res.size()+1,res.c_str());
|
||||
std::strcpy(cString,res.c_str());
|
||||
return cString;
|
||||
}
|
||||
|
||||
int NvrUTCDiff(void* PtrHIKNvr){
|
||||
auto* HIKNvrObj = (HIKNvr*)PtrHIKNvr;
|
||||
return HIKNvrObj->GetNvrUTCDiff();
|
||||
}
|
||||
25
main.go
25
main.go
@@ -1,25 +0,0 @@
|
||||
package main
|
||||
|
||||
import "fmt"
|
||||
|
||||
func main() {
|
||||
SdkInitState := DVR_Init()
|
||||
println(SdkInitState)
|
||||
//BallCamera := NewHIKBallCamera()
|
||||
//res := BallCamera.Login("192.168.211.49", "8000", "admin", "Max123456", "BuKongQiu")
|
||||
//if !res {
|
||||
// fmt.Println("Login Failed")
|
||||
// //return
|
||||
//}
|
||||
//var P, T, Z float32
|
||||
//println(BallCamera.PTZGet(&P, &T, &Z))
|
||||
Nvr := NewHIKNvr()
|
||||
res := Nvr.Login("192.168.211.124", "8000", "admin", "guanyaokeji8520", 1)
|
||||
if !res {
|
||||
fmt.Println("Login Failed")
|
||||
return
|
||||
}
|
||||
fmt.Println(Nvr.CheckTimeRegionWithMonth(2024, 10))
|
||||
fmt.Println(Nvr.CheckTimeRegionWithDay(2024, 10, 8))
|
||||
|
||||
}
|
||||
@@ -3,7 +3,7 @@
|
||||
|
||||
//go:build darwin || freebsd || linux
|
||||
|
||||
package main
|
||||
package HikNetSDK
|
||||
|
||||
import "github.com/ebitengine/purego"
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
// SPDX-FileCopyrightText: 2023 The Ebitengine Authors
|
||||
|
||||
package main
|
||||
package HikNetSDK
|
||||
|
||||
import "syscall"
|
||||
|
||||
|
||||
@@ -21,14 +21,14 @@ bool HIKBallCamera::InitBallCamera(std::string ip, std::string port, std::string
|
||||
{
|
||||
int res = Login(ip, port, username, password);
|
||||
if (res != 0){
|
||||
std::cout << "Incorrect Login" << std::endl;
|
||||
std::cout << "Incorrect Login error code:" << res << std::endl;
|
||||
return false;
|
||||
}
|
||||
|
||||
m_Channel = DeviceInfo.byStartChan;
|
||||
this->BallMachineType = BallMachineType;
|
||||
|
||||
//建立透明通道
|
||||
if (BallMachineType == "BuKongQiu"){
|
||||
NET_DVR_SERIALSTART_V40 struSerialParam = { 0 };
|
||||
struSerialParam.dwSize = sizeof(struSerialParam);
|
||||
struSerialParam.dwSerialType = 2;//1:232串口;2:485串口
|
||||
@@ -41,7 +41,7 @@ bool HIKBallCamera::InitBallCamera(std::string ip, std::string port, std::string
|
||||
NET_DVR_Cleanup();
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -93,7 +93,7 @@ bool HIKBallCamera::PtzControlRight(int speed,int state)
|
||||
SerialSend(PrepareHexString(buf));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(PAN_RIGHT, 0, speed);
|
||||
return PtzControl(PAN_RIGHT, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -105,7 +105,7 @@ bool HIKBallCamera::PtzControlUp(int speed,int state)
|
||||
SerialSend(PrepareHexString(buf));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(TILT_UP, 0, speed);
|
||||
return PtzControl(TILT_UP, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -117,7 +117,7 @@ bool HIKBallCamera::PtzControlDown(int speed,int state)
|
||||
SerialSend(PrepareHexString(buf));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(TILT_DOWN, 0, speed);
|
||||
return PtzControl(TILT_DOWN, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -127,7 +127,7 @@ bool HIKBallCamera::PtzControlZoomIn(int speed,int state)
|
||||
SerialSend(PrepareHexString("ff 01 00 20 00 00 21"));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(ZOOM_IN, 0, speed);
|
||||
return PtzControl(ZOOM_IN, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -137,7 +137,7 @@ bool HIKBallCamera::PtzControlZoomOut(int speed,int state)
|
||||
SerialSend(PrepareHexString("ff 01 00 40 00 00 41"));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(ZOOM_OUT, 0, speed);
|
||||
return PtzControl(ZOOM_OUT, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -148,7 +148,7 @@ bool HIKBallCamera::PtzControlFocusAdd(int speed,int state){
|
||||
SerialSend(PrepareHexString("ff 01 01 00 00 00 02"));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(ZOOM_OUT, 1, speed);
|
||||
return PtzControl(FOCUS_FAR, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -158,7 +158,7 @@ bool HIKBallCamera::PtzControlFocusSub(int speed,int state){
|
||||
SerialSend(PrepareHexString("ff 01 00 80 00 00 81"));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(ZOOM_OUT, 1, speed);
|
||||
return PtzControl(FOCUS_NEAR, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -188,7 +188,7 @@ bool HIKBallCamera::PtzControlUpRight(int speed,int state)
|
||||
SerialSend(PrepareHexString(buf));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(UP_RIGHT, 0, speed);
|
||||
return PtzControl(UP_RIGHT, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -200,7 +200,7 @@ bool HIKBallCamera::PtzControlDownLeft(int speed,int state)
|
||||
SerialSend(PrepareHexString(buf));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(DOWN_LEFT, 0, speed);
|
||||
return PtzControl(DOWN_LEFT, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -212,7 +212,7 @@ bool HIKBallCamera::PtzControlDownRight(int speed,int state)
|
||||
SerialSend(PrepareHexString(buf));
|
||||
return true;
|
||||
}else{
|
||||
return PtzControl(DOWN_RIGHT, 0, speed);
|
||||
return PtzControl(DOWN_RIGHT, state, speed);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -283,7 +283,8 @@ bool HIKBallCamera::PtzGotoPut(int Action, float P, float T, float Z)
|
||||
NET_DVR_PTZPOS ptzPosCurrent;
|
||||
ptzPosCurrent.wPanPos = DEC2HEX(P);
|
||||
ptzPosCurrent.wTiltPos = DEC2HEX(T);
|
||||
ptzPosCurrent.wAction = 5;
|
||||
ptzPosCurrent.wZoomPos = DEC2HEX(Z);
|
||||
ptzPosCurrent.wAction = Action;
|
||||
|
||||
bool b = NET_DVR_SetDVRConfig(LoginID, NET_DVR_SET_PTZPOS, m_Channel, &ptzPosCurrent, sizeof(NET_DVR_PTZPOS));
|
||||
return b;
|
||||
@@ -315,9 +316,9 @@ bool HIKBallCamera::PtzGet(float* posP, float* posT, float* posZ) {
|
||||
float P = HEX2DEC(ptzPosCurrent.wPanPos);
|
||||
float T = HEX2DEC(ptzPosCurrent.wTiltPos);
|
||||
float Z = HEX2DEC(ptzPosCurrent.wZoomPos);
|
||||
posP = &P;
|
||||
posT = &T;
|
||||
posZ = &Z;
|
||||
*posP = P;
|
||||
*posT = T;
|
||||
*posZ = Z;
|
||||
return b;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -19,8 +19,7 @@ int HIKBase::Login(std::string ip, std::string port, std::string username, std::
|
||||
Password = password;
|
||||
|
||||
LoginID = NET_DVR_Login_V30((char *)Ip.c_str(), atoi(Port.c_str()), (char *)Username.c_str(), (char *)Password.c_str(), &DeviceInfo);
|
||||
std::cout << LoginID <<std::endl;
|
||||
return LoginID;
|
||||
return NET_DVR_GetLastError();
|
||||
}
|
||||
|
||||
void HIKBase::Logout()
|
||||
|
||||
@@ -27,15 +27,14 @@ bool HIKNvr::InitNvr(std::string ip, std::string port, std::string username, std
|
||||
return false;
|
||||
}
|
||||
|
||||
bool HIKNvr::GetNvrUTCDiff(){
|
||||
int HIKNvr::GetNvrUTCDiff(){
|
||||
NET_DVR_NETAPPCFG struNAC = {0};
|
||||
DWORD ZoneSize = 0;
|
||||
NET_DVR_GetDVRConfig(LoginID, NET_DVR_GET_NETAPPCFG, 0, &struNAC, sizeof(NET_DVR_NETAPPCFG), &ZoneSize);
|
||||
int nDiffHour = struNAC.struNtpClientParam.cTimeDifferenceH;
|
||||
int nDiffMin = struNAC.struNtpClientParam.cTimeDifferenceM;
|
||||
|
||||
nDiffTotalMin = (nDiffHour < 0 ? -1 : 1) * (abs(nDiffHour) * 60 + nDiffMin);
|
||||
return true;
|
||||
return (nDiffHour < 0 ? -1 : 1) * (abs(nDiffHour) * 60 + nDiffMin);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -42,7 +42,7 @@ public:
|
||||
//though input SelectTime get the time region
|
||||
bool GetTimeRegion(DateTime select_time,int value ,DateTime &time_start,DateTime &time_end);
|
||||
|
||||
bool GetNvrUTCDiff();
|
||||
int GetNvrUTCDiff();
|
||||
int nDiffTotalMin;
|
||||
|
||||
public:
|
||||
|
||||
Reference in New Issue
Block a user