Browse Source

[完善]三个配置文件

develop
邵佳豪 3 years ago
parent
commit
14178b3a35
  1. 3
      src/app/app.module.ts
  2. 10
      src/app/service/configFormData.service.ts
  3. 2
      src/app/system-management/config-form/config-form.component.html
  4. 318
      src/app/system-management/config-form/config-form.component.ts
  5. 300
      src/app/system-management/host-config/host-config.component.ts

3
src/app/app.module.ts

@ -13,6 +13,7 @@ import { NzMessageModule } from 'ng-zorro-antd/message';
import { TreeService } from './service/tree.service';
import { RouteReuseStrategy } from '@angular/router';
import { CustomReuseStrategy } from './CustomReuseStrategy';
import { ConfigFormDataService } from './service/configFormData.service';
@NgModule({
declarations: [
AppComponent
@ -27,7 +28,7 @@ import { CustomReuseStrategy } from './CustomReuseStrategy';
NzNotificationModule,
NzMessageModule
],
providers: [httpInterceptorProviders, CacheTokenService, TreeService,
providers: [httpInterceptorProviders, CacheTokenService, TreeService, ConfigFormDataService,
{ provide: RouteReuseStrategy, useClass: CustomReuseStrategy }],
bootstrap: [AppComponent]
})

10
src/app/service/configFormData.service.ts

@ -0,0 +1,10 @@
import { Injectable } from '@angular/core';
@Injectable()
export class ConfigFormDataService {
tableData: any//摄像头列表数据
config1: any//配置文件
config2: any//配置文件
config3: any//配置文件
config4: any//配置文件
}

2
src/app/system-management/config-form/config-form.component.html

@ -10,6 +10,6 @@
</nz-tabset>
</div>
<div class="btnbox">
<button nz-button nzType="primary">发送配置文件</button>
<button nz-button nzType="primary" (click)="putConfig()">发送配置文件</button>
</div>
</div>

318
src/app/system-management/config-form/config-form.component.ts

@ -1,4 +1,7 @@
import { HttpClient } from '@angular/common/http';
import { Component, OnInit } from '@angular/core';
import { ActivatedRoute } from '@angular/router';
import { ConfigFormDataService } from 'src/app/service/configFormData.service';
@Component({
selector: 'app-config-form',
@ -7,301 +10,36 @@ import { Component, OnInit } from '@angular/core';
})
export class ConfigFormComponent implements OnInit {
constructor() { }
constructor(public configFormData: ConfigFormDataService, private http: HttpClient, private route: ActivatedRoute) { }
config1: string
config2: string
config3: string
config4: string
hostId//主机id
orId//加油站id
ngOnInit(): void {
this.hostId = this.route.snapshot.queryParams.hostId
this.orId = this.route.snapshot.queryParams.orId
this.config1 = sessionStorage.getItem('config1')
this.config2 = sessionStorage.getItem('config2')
this.config3 = sessionStorage.getItem('config3')
this.config4 = sessionStorage.getItem('config4')
}
goback() {
history.go(-1)
}
putConfig() {
let body = {
configFiles: "string"
}
this.http.put(`/api/EdgeDevices/${this.hostId}`, body).subscribe({
next: (data) => {
config1: string = `[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]
#chaoyang-out174
#enable or disable following feature
enable=1
#ROI to filter select objects, and remove from meta data
roi-RF=100;1080;1920;1080;1200;350;500;350
#remove objects in the ROI
inverse-roi=0
class-id=-1
# ## Per stream configuration
# [roi-filtering-stream-1]
# #chaoyang-out171
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=1493;782;1893;782;1796;1077;951;1080
# #remove objects in the ROI
# inverse-roi=0
# class-id=-1
# ## Per stream configuration
# [roi-filtering-stream-2]
# #chaoyang-out171
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=0;1080;1920;1080;1920;540;0;200
# #remove objects in the ROI
# inverse-roi=0
# class-id=-1
## Per stream configuration
[roi-filtering-stream-3]
#chaoyang-out171
#enable or disable following feature
enable=1
#ROI to filter select objects, and remove from meta data
roi-RF= 0;0;0;0;0;0;0;0
#remove objects in the ROI
inverse-roi=0
class-id=-1
# ## Per stream configuration
# [roi-filtering-stream-4]
# #chaoyang-out181
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=200;0;650;0;650;500;200;500
# #remove objects in the ROI
# inverse-roi=0
# class-id=0
# ## Per stream configuration
# [roi-filtering-stream-5]
# #chaoyang-out181
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=930;93;1870;93;1870;1080;930;1080
# #remove objects in the ROI
# inverse-roi=0
# class-id=0
# ## Per stream configuration
# [roi-filtering-stream-6]
# #chaoyang-out166
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=1174;151;1920;151;1920;1080;1174;1080
# #remove objects in the ROI
# inverse-roi=0
# class-id=-1
# ## Per stream configuration
# [roi-filtering-stream-7]
# #chaoyang-out166
# #enable or disable following feature
# enable=1
# #ROI to filter select objects, and remove from meta data
# roi-RF=1450;300;1910;300;1910;950;1450;950
# #remove objects in the ROI
# inverse-roi=0
# class-id=-1
[line-crossing-stream-1]
enable=1
#Label;direction;lc
line-crossing-Entry=1791;473;1570;845;1400;782;1893;782
# 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=loose
[line-crossing-stream-3]
enable=1
#Label;direction;lc
line-crossing-Entry=900;600;500;600;900;1080;550;300
# 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=loose`
config2: string = `# 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'
tracker:
config: 'config/dstest_tracker_config.txt'
analytics:
config: 'config/config_nvdsanalytics.txt'
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: 100
detected-min-h: 100
actionnet:
enable: false
apply_on: 1
# roi:
# - 'fuel_island-4':
# - [200, 0, 450, 500]
# - 'fuel_island-5':
# - [930, 93, 940, 987]
# - 'fuel_island-6':
# - [1174, 151, 746, 929]
# - 'fuel_island-7':
# - [1450, 300, 460, 650]
interval: 1
batch_size: 32
idnet:
enable: true
apply_on: -1
interval: 1
batch_size: 32
oilnet:
enable: true
apply_on: 2
interval: 1
batch_size: 16
topk: 5
roi-top-offset: 0
roi-bottom-offset: 0
detected-min-w: 20
detected-min-h: 20
smoke_fire_net:
enable: true
apply_on: -1
interval: 1
batch_size: 16
smoking_calling_net:
enable: true
apply_on: -1
interval: 1
batch_size: 32
connet:
enable: true
apply_on: 2
roi:
- 'oil_tube-3':
- [270, 350, 600, 250]
- 'grounder-3':
- [290, 200, 580, 250]
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`
},
error: (err) => {
console.log('连接失败', err)
}
})
}
config3: string = `logging_interval: 600
test_action: true # trigger for imaging capturing, when set to False, image is captured based on fixed time interval, otherwise on rules`
config4: string = `#Chaoyang RTSP sources
video_rate: 5
inference_buffer_second: 10
sources:
- name: 'Sources 0'
user: 'admin'
password: 'a12345678'
uri: 'rtsp://10.28.91.170:554/Streaming/Channels/101?transportmode=unicast'
type: 0
- name: 'Sources 1'
user: 'admin'
password: 'Aa88888888'
uri: 'rtsp://10.28.91.174:554/Streaming/Channels/101?transportmode=unicast'
type: 3
- name: 'Sources 2'
user: 'admin'
password: 'a12345678'
uri: 'rtsp://10.28.91.164:554/Streaming/Channels/101?transportmode=unicast'
type: 0
- name: 'Sources 3'
user: 'admin'
password: 'Aa88888888'
uri: 'rtsp://10.28.91.133:554/Streaming/Channels/101?transportmode=unicast'
type: 2
- name: 'Sources 4'
user: 'admin'
password: 'Aa88888888'
uri: 'rtsp://10.28.91.171:554/Streaming/Channels/101?transportmode=unicast'
type: 1
- name: 'Sources 5'
user: 'admin'
password: 'Aa88888888'
uri: 'rtsp://10.28.91.181:554/Streaming/Channels/101?transportmode=unicast'
type: 1
- name: 'Sources 6'
user: 'admin'
password: 'Aa88888888'
uri: 'rtsp://10.28.91.166:554/Streaming/Channels/101?transportmode=unicast'
type: 1
- name: 'Sources 7'
user: 'admin'
password: 'a12345678'
uri: 'rtsp://10.28.91.161:554/Streaming/Channels/101?transportmode=unicast'
type: 1`
}

300
src/app/system-management/host-config/host-config.component.ts

@ -8,6 +8,7 @@ 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;
@ -25,7 +26,7 @@ interface Camera {
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) { }
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
@ -132,7 +133,7 @@ export class HostConfigComponent implements OnInit {
});
}
label(item){
label(item) {
this.router.navigate(['/system/host/camera/imageLabel'])
}
@ -147,15 +148,300 @@ export class HostConfigComponent implements OnInit {
}).subscribe({
next: (data) => {
console.log('连接状态', data)
// this.router.navigate(['/system/host/camera/imageList'])
this.router.navigate(['/system/host/camera/configForm'])
this.disposalData()
this.router.navigate(['/system/host/camera/configForm'], { queryParams: { 'hostId': this.hostId, 'orId': this.orId } })
},
error: (err) => {
console.log('连接失败', err)
},
// complete: () => console.log('complete!'), // not called
}
})
}
//整理配置文件数据
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)
}
}

Loading…
Cancel
Save