Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
osie
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
osie
Commits
879f779d
Commit
879f779d
authored
May 20, 2024
by
Ivan Tyagov
Browse files
Options
Browse Files
Download
Plain Diff
Oi sensor
See merge request
!50
parents
6a8981fd
9af7c90e
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
39 additions
and
15 deletions
+39
-15
oi-sensor/oi-sensor.py
oi-sensor/oi-sensor.py
+39
-15
No files found.
oi-sensor/oi-sensor.py
View file @
879f779d
...
@@ -20,16 +20,26 @@ import argparse
...
@@ -20,16 +20,26 @@ import argparse
SLEEP_DURATION
=
10e-3
# 10 milliseconds
SLEEP_DURATION
=
10e-3
# 10 milliseconds
# algorith defaults
DEFAULT_LH
=
(
0
,
180
,)
DEFAULT_LS
=
(
0
,
255
,)
DEFAULT_LV
=
(
0
,
255
,)
DEFAULT_UH
=
(
135
,
180
,)
DEFAULT_US
=
(
190
,
255
,)
DEFAULT_UV
=
(
190
,
255
,)
# command line handling
# command line handling
parser
=
argparse
.
ArgumentParser
(
description
=
'Run optical inspection OPC UA server.'
)
parser
=
argparse
.
ArgumentParser
(
description
=
'Run optical inspection OPC UA server.'
)
a
=
parser
.
add_argument
a
=
parser
.
add_argument
a
(
'--ipv4'
,
help
=
'The IPv4 address on which the OPC UA server runs'
,
default
=
"0.0.0.0"
)
a
(
'--ipv4'
,
help
=
'The IPv4 address on which the OPC UA server runs'
,
default
=
"0.0.0.0"
)
a
(
'--port'
,
help
=
'The port on which the OPC UA server runs'
,
default
=
"4840"
)
a
(
'--port'
,
help
=
'The port on which the OPC UA server runs'
,
default
=
"4840"
)
a
(
'--camera'
,
help
=
'The index of the camera (i.e. indxed in /dev/videoX)'
,
default
=
0
)
a
(
'--camera'
,
help
=
'The index of the camera (i.e. indxed in /dev/videoX)'
,
default
=
0
)
a
(
'--headless'
,
help
=
'Run without screen in a headless mode (boolean, default=0)'
,
default
=
False
)
args
=
parser
.
parse_args
()
args
=
parser
.
parse_args
()
ipv4
=
args
.
ipv4
ipv4
=
args
.
ipv4
port
=
args
.
port
port
=
args
.
port
camera
=
int
(
args
.
camera
)
camera
=
int
(
args
.
camera
)
headless
=
bool
(
int
(
args
.
headless
))
def
nothing
(
x
):
def
nothing
(
x
):
# any operation
# any operation
...
@@ -53,14 +63,16 @@ async def main():
...
@@ -53,14 +63,16 @@ async def main():
# init camera
# init camera
cap
=
cv2
.
VideoCapture
(
camera
)
cap
=
cv2
.
VideoCapture
(
camera
)
cv2
.
namedWindow
(
"Trackbars"
)
cv2
.
createTrackbar
(
"L-H"
,
"Trackbars"
,
0
,
180
,
nothing
)
cv2
.
createTrackbar
(
"L-S"
,
"Trackbars"
,
0
,
255
,
nothing
)
cv2
.
createTrackbar
(
"L-V"
,
"Trackbars"
,
0
,
255
,
nothing
)
cv2
.
createTrackbar
(
"U-H"
,
"Trackbars"
,
135
,
180
,
nothing
)
cv2
.
createTrackbar
(
"U-S"
,
"Trackbars"
,
190
,
255
,
nothing
)
cv2
.
createTrackbar
(
"U-V"
,
"Trackbars"
,
190
,
255
,
nothing
)
font
=
cv2
.
FONT_HERSHEY_COMPLEX
font
=
cv2
.
FONT_HERSHEY_COMPLEX
if
not
headless
:
# create UI
cv2
.
namedWindow
(
"Trackbars"
)
cv2
.
createTrackbar
(
"L-H"
,
"Trackbars"
,
DEFAULT_LH
[
0
],
DEFAULT_LH
[
1
],
nothing
)
cv2
.
createTrackbar
(
"L-S"
,
"Trackbars"
,
DEFAULT_LS
[
0
],
DEFAULT_LS
[
1
],
nothing
)
cv2
.
createTrackbar
(
"L-V"
,
"Trackbars"
,
DEFAULT_LV
[
0
],
DEFAULT_LV
[
1
],
nothing
)
cv2
.
createTrackbar
(
"U-H"
,
"Trackbars"
,
DEFAULT_UH
[
0
],
DEFAULT_UH
[
1
],
nothing
)
cv2
.
createTrackbar
(
"U-S"
,
"Trackbars"
,
DEFAULT_US
[
0
],
DEFAULT_US
[
1
],
nothing
)
cv2
.
createTrackbar
(
"U-V"
,
"Trackbars"
,
DEFAULT_UV
[
0
],
DEFAULT_UV
[
1
],
nothing
)
_logger
.
info
(
"Starting server!"
)
_logger
.
info
(
"Starting server!"
)
async
with
server
:
async
with
server
:
...
@@ -73,12 +85,22 @@ async def main():
...
@@ -73,12 +85,22 @@ async def main():
# read and process camera
# read and process camera
_
,
frame
=
cap
.
read
()
_
,
frame
=
cap
.
read
()
hsv
=
cv2
.
cvtColor
(
frame
,
cv2
.
COLOR_BGR2HSV
)
hsv
=
cv2
.
cvtColor
(
frame
,
cv2
.
COLOR_BGR2HSV
)
if
not
headless
:
l_h
=
cv2
.
getTrackbarPos
(
"L-H"
,
"Trackbars"
)
l_h
=
cv2
.
getTrackbarPos
(
"L-H"
,
"Trackbars"
)
l_s
=
cv2
.
getTrackbarPos
(
"L-S"
,
"Trackbars"
)
l_s
=
cv2
.
getTrackbarPos
(
"L-S"
,
"Trackbars"
)
l_v
=
cv2
.
getTrackbarPos
(
"L-V"
,
"Trackbars"
)
l_v
=
cv2
.
getTrackbarPos
(
"L-V"
,
"Trackbars"
)
u_h
=
cv2
.
getTrackbarPos
(
"U-H"
,
"Trackbars"
)
u_h
=
cv2
.
getTrackbarPos
(
"U-H"
,
"Trackbars"
)
u_s
=
cv2
.
getTrackbarPos
(
"U-S"
,
"Trackbars"
)
u_s
=
cv2
.
getTrackbarPos
(
"U-S"
,
"Trackbars"
)
u_v
=
cv2
.
getTrackbarPos
(
"U-V"
,
"Trackbars"
)
u_v
=
cv2
.
getTrackbarPos
(
"U-V"
,
"Trackbars"
)
else
:
# read defaults provided
l_h
=
DEFAULT_LH
[
0
]
l_s
=
DEFAULT_LS
[
0
]
l_v
=
DEFAULT_LV
[
0
]
u_h
=
DEFAULT_UH
[
0
]
u_s
=
DEFAULT_US
[
0
]
u_v
=
DEFAULT_UV
[
0
]
lower_red
=
np
.
array
([
l_h
,
l_s
,
l_v
])
lower_red
=
np
.
array
([
l_h
,
l_s
,
l_v
])
upper_red
=
np
.
array
([
u_h
,
u_s
,
u_v
])
upper_red
=
np
.
array
([
u_h
,
u_s
,
u_v
])
...
@@ -110,6 +132,8 @@ async def main():
...
@@ -110,6 +132,8 @@ async def main():
else
:
else
:
await
myvar
.
write_value
(
0.0
)
await
myvar
.
write_value
(
0.0
)
# show current MASK and camera output windows
if
not
headless
:
cv2
.
imshow
(
"Frame"
,
frame
)
cv2
.
imshow
(
"Frame"
,
frame
)
cv2
.
imshow
(
"Mask"
,
mask
)
cv2
.
imshow
(
"Mask"
,
mask
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment