中化项目-边缘主机维护-前端项目
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

448 lines
13 KiB

import { Component, OnInit, ViewContainerRef } from '@angular/core';
import { ActivatedRoute, Route, Router } from '@angular/router';
import { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';
import { NzFormTooltipIcon } from 'ng-zorro-antd/form';
import { NzModalService } from 'ng-zorro-antd/modal';
import { AddcameraComponent } from './addcamera/addcamera.component';
import { NzMessageService } from 'ng-zorro-antd/message';
import { HttpClient, HttpErrorResponse, HttpResponse } from '@angular/common/http';
import { EditcameraComponent } from './editcamera/editcamera.component';
import { catchError, tap } from 'rxjs/operators';
import { ConfigFormDataService } from 'src/app/service/configFormData.service';
interface Camera {
name: string;
user: string;
password: string;
uri: string;
type: number
}
@Component({
selector: 'app-host-config',
templateUrl: './host-config.component.html',
styleUrls: ['./host-config.component.scss']
})
export class HostConfigComponent implements OnInit {
constructor(private router: Router, private route: ActivatedRoute, private fb: FormBuilder, private modal: NzModalService, private message: NzMessageService, private viewContainerRef: ViewContainerRef, private http: HttpClient, public configFormData: ConfigFormDataService,) { }
hostId//主机id
orId//加油站id
ngOnInit(): void {
this.hostId = this.route.snapshot.queryParams.hostId
this.orId = this.route.snapshot.queryParams.orId
this.getCamera()
}
listOfData: Camera[] = [];
goback() {
history.go(-1)
}
//摄像头
getCamera() {
this.http.get('/api/Cameras').subscribe((data: any) => {
this.listOfData = data.items
console.log('摄像头列表', data.items)
})
}
addCamera() {
const modal = this.modal.create({
nzTitle: '新增加油站摄像头',
nzContent: AddcameraComponent,
nzViewContainerRef: this.viewContainerRef,
nzWidth: 388,
nzComponentParams: {},
nzOnOk: async () => {
if (instance.validateForm.valid) {
await new Promise(resolve => {
console.log('表单信息', instance.validateForm)
let body = {
name: instance.validateForm.value.name,
user: instance.validateForm.value.user,
password: instance.validateForm.value.password,
uri: instance.validateForm.value.uri,
type: instance.validateForm.value.type,
organizationId: this.orId
}
this.http.post('/api/Cameras', body).subscribe(data => {
resolve(data)
this.message.create('success', '创建成功!');
this.getCamera()
return true
})
})
} else {
this.message.create('warning', '请填写完整!');
return false
}
}
});
const instance = modal.getContentComponent();
}
editCamera(data) {
console.log(data)
const modal = this.modal.create({
nzTitle: '编辑加油站摄像头',
nzContent: EditcameraComponent,
nzViewContainerRef: this.viewContainerRef,
nzWidth: 388,
nzComponentParams: {
data: data
},
nzOnOk: async () => {
if (instance.validateForm.valid) {
await new Promise(resolve => {
console.log('表单信息', instance.validateForm)
let body = {
name: instance.validateForm.value.name,
user: instance.validateForm.value.user,
password: instance.validateForm.value.password,
uri: instance.validateForm.value.uri,
type: instance.validateForm.value.type,
organizationId: this.orId
}
this.http.put(`/api/Cameras/${data.id}`, body).subscribe(data => {
resolve(data)
this.message.create('success', '创建成功!');
this.getCamera()
return true
})
})
} else {
this.message.create('warning', '请填写完整!');
return false
}
}
});
const instance = modal.getContentComponent();
}
deleteCamera(item) {
console.log(item)
this.modal.confirm({
nzTitle: `确定要删除${item.name}这个摄像头吗?`,
nzOkText: '确定',
nzOkType: 'default',
nzOnOk: () => {
this.http.delete(`/api/Cameras/${item.id}`).subscribe(data => {
this.message.create('success', '删除成功!');
this.getCamera()
})
},
nzCancelText: '取消'
});
}
label(item) {
this.router.navigate(['/system/host/camera/imageLabel'])
}
connect() {
let ids = []
this.listOfData.forEach((item: any) => {
ids.push(item.id)
})
this.http.get('/api/Cameras/Statuses', {
params: { ids: ids }
}).subscribe({
next: (data) => {
console.log('连接状态', data)
this.disposalData()
this.router.navigate(['/system/host/camera/configForm'], { queryParams: { 'hostId': this.hostId, 'orId': this.orId } })
},
error: (err) => {
console.log('连接失败', err)
}
})
}
//整理配置文件数据
disposalData() {
console.log(this.listOfData)
let config1 = `[property]
enable=1
#Width height used for configuration to which below configs are configured
config-width=1980
config-height=1080
#osd-mode 0: Dont display any lines, rois and text
# 1: Display only lines, rois and static text i.e. labels
# 2: Display all info from 1 plus information about counts
osd-mode=2
#Set OSD font size that has to be displayed
display-font-size=12
## Per stream configuration
[roi-filtering-stream-0]
#shoushiyuan-out202
#enable or disable following feature
enable=1
#ROI to filter select objects, and remove from meta data
roi-RF=1052;119;76;1066;1908;1071;1797;180
#remove objects in the ROI
inverse-roi=0
class-id=-1
# ## Per stream configuration
# [roi-filtering-stream-1]
# #shoushiyuan-out206
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=443;660;660;1076;1113;1079;638;541
# #remove objects in the ROI
# inverse-roi=0
# class-id=-1
## Per stream configuration
[roi-filtering-stream-2]
#shoushiyuan-out210
#enable or disable following feature
enable=1
#ROI to filter select objects, and remove from meta data
roi-RF=10;323;227;1073;1908;1066;1909;370;1291;166
#remove objects in the ROI
inverse-roi=0
class-id=0
# ## Per stream configuration
# [roi-filtering-stream-3]
# #shoushiyuan-out211
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=587;447;405;1063;1904;1063;1334;602
# #remove objects in the ROI
# inverse-roi=0
# class-id=-1
# ## Per stream configuration
# [roi-filtering-stream-4]
# #shoushiyuan-out214 2
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=687;227;1025;227;1025;688;687;688
# #remove objects in the ROI
# inverse-roi=0
# class-id=0
# ## Per stream configuration
# [roi-filtering-stream-5]
# #shoushiyuan-out215 3
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=649;139;956;139;956;528;649;528
# # 659;139;956;139;956;448;659;448
# #remove objects in the ROI
# inverse-roi=0
# class-id=0
# ## Per stream configuration
# [roi-filtering-stream-6]
# #shoushiyuan-out216
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=840;152;1102;152;1102;601;840;601
# #remove objects in the ROI
# inverse-roi=0
# class-id=0
# ## Per stream configuration
# [roi-filtering-stream-7]
# #shoushiyuan-out217 4
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=886;248;1163;248;1163;627;886;627
# #remove objects in the ROI
# inverse-roi=0
# class-id=0
[line-crossing-stream-1]
enable=1
#Label;direction;lc
line-crossing-Entry=471;540;570;689;443;660;638;541
# line-crossing-Exit=789;672;1084;900;851;773;1203;732
class-id=0
#extended when 0- only counts crossing on the configured Line
# 1- assumes extended Line crossing counts all the crossing
extended=0
#LC modes supported:
#loose : counts all crossing without strong adherence to direction
#balanced: Strict direction adherence expected compared to mode=loose
#strict : Strict direction adherence expected compared to mode=balanced
mode=strict
[line-crossing-stream-3]
enable=1
#Label;direction;lc
line-crossing-Entry=685;794;361;704;587;447;405;1063
# line-crossing-Exit=789;672;1084;900;1908;827;685;436
class-id=0
#extended when 0- only counts crossing on the configured Line
# 1- assumes extended Line crossing counts all the crossing
extended=0
#LC modes supported:
#loose : counts all crossing without strong adherence to direction
#balanced: Strict direction adherence expected compared to mode=loose
#strict : Strict direction adherence expected compared to mode=balanced
mode=strict
# [overcrowding-stream-1]
# enable=1
# roi-OC=295;643;579;634;642;913;56;828
# #no of objects that will trigger OC
# object-threshold=2
# class-id=-1
`
let config2 = `# The all in one config file.
# RTSP sources
# type
# 0 ViolateArea.ENTRANCE,
# 1 ViolateArea.GAS_AREA,
# 2 ViolateArea.FUEL_AREA,
# 3 ViolateArea.MART,
# don't change the key name.
debug: true #when the debug is on, osd.
sources:
config: 'config/source.yaml'
streammux:
width: 1980
height: 1080
batch-size: 32
batched-push-timeout: 4000000
live-source: true
sync-inputs: true
sourcebin:
buffer-duration: 1000000000
buffer-size: 102400
tracker:
config: 'config/dstest_tracker_config.txt'
analytics:
config: 'config/config_nvdsanalytics.txt'
osd:
enable: false
ipaddr: '0.0.0.0'
port: 8554
out_path: 'test'
peoplenet:
enable: true
apply_on: -1
interval: 1
batch_size: 16
topk: 5
roi-top-offset: 0
roi-bottom-offset: 0
detected-min-w: 20
detected-min-h: 200
trafficcam:
enable: true
apply_on: 0
interval: 1
batch_size: 16
topk: 5
roi-top-offset: 0
roi-bottom-offset: 0
detected-min-w: 200
detected-min-h: 200
actionnet:
enable: false
apply_on: 1
interval: 1
batch_size: 32
# roi:
# - 'fuel_island-4':
# - [672, 227, 366, 471]
# - 'fuel_island-5':
# - [649, 139, 307, 389]
# - 'fuel_island-6':
# - [805, 152, 297, 430]
# - 'fuel_island-7':
# - [876, 248, 287, 409]
idnet:
enable: true
apply_on: -1
interval: 1
batch_size: 32
oilnet:
enable: true
apply_on: 2
interval: 1
batch_size: 16
roi-top-offset: 0
roi-bottom-offset: 0
detected-min-w: 30
detected-min-h: 0
smoke_fire_net:
enable: false
apply_on: -1
interval: 1
batch_size: 16
smoking_calling_net:
enable: true
apply_on: -1
interval: 1
batch_size: 32
connet:
enable: false
apply_on: 2
roi:
- 'oil_tube-3':
- [490, 370, 381, 168]
- 'grounder-3':
- [585, 334, 289, 139]
interval: 1
batch_size: 2
#new field for rule threshold
rule_threshold:
object_occurence_interval_second: 15
object_disappear_interval_second: 60
on_car_parking_interval_second: 1800
threshold_relying_sitting: 0.4 #rolling mean confidence
threshold_smoking_calling: 0.8 #rolling mean confidence
threshold_connecting: 0.667 #rolling mean confidence
threshold_identity: 0.1 #only to filter out people net error
`
let config3 = `test_action: true
logging_interval : 600
`
let config4 = `#RTSP sources for file source, use file as the
#Shoushi Yuan RTSP sources
video_rate: 5
inference_buffer_second: 10`
this.listOfData.forEach((item: any) => {
config4 += `
- name: '${item.name}'
user: '${item.user}'
password: '${item.password}'
uri: '${item.uri}'
type: ${item.type}
`
})
sessionStorage.setItem('config1', config1)
sessionStorage.setItem('config2', config2)
sessionStorage.setItem('config3', config3)
sessionStorage.setItem('config4', config4)
console.log('config4', config4)
}
}