Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
elphel-web-393
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Elphel
elphel-web-393
Commits
2d52ff11
Commit
2d52ff11
authored
May 20, 2020
by
Oleg Dzhimiev
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
updated jquery-jp4.js
parent
41e36cff
Changes
7
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
332 additions
and
424 deletions
+332
-424
elphel.js
src/jp4-canvas/elphel.js
+4
-4
jp4-canvas.html
src/jp4-canvas/jp4-canvas.html
+4
-4
jp4-canvas.js
src/jp4-canvas/jp4-canvas.js
+5
-5
jquery-jp4.js
src/jp4-canvas/jquery-jp4.js
+282
-376
webworker.js
src/jp4-canvas/webworker.js
+33
-32
jp4-viewer.js
src/jp4-viewer/jp4-viewer.js
+1
-1
multicam.js
src/multicam/multicam.js
+3
-2
No files found.
src/jp4-canvas/elphel.js
View file @
2d52ff11
...
...
@@ -129,13 +129,13 @@ var Elphel = {
* @lowres - valid values: 1 (not scaled), 2, 4, 8 (lowest resolution)
*
*/
reorderBlocksJP4_lowres
:
function
(
pixels
,
width
,
height
,
format
=
"JP4"
,
mosaic
=
[[
"Gr"
,
"R"
],[
"B"
,
"Gb"
]],
lowres
){
//
reorderBlocksJP4_lowres: function(pixels,width,height,format="JP4",mosaic=[["Gr","R"],["B" ,"Gb"]],lowres){
reorderBlocksJP4_lowres
:
async
function
(
pixels
,
width
,
height
,
format
=
"JP4"
,
mosaic
=
[[
"Gr"
,
"R"
],[
"B"
,
"Gb"
]],
lowres
){
// the output image is 1/4 because demosaicing = 4 single color channel pixels are put into 1 rgb pixel
var
oPixels
=
new
Uint8Array
(
pixels
.
length
/
4
);
// check
if
(
(
lowres
!=
1
)
&&
(
lowres
!=
2
)
&&
(
lowres
!=
4
)
&&
(
lowres
!=
8
)){
if
(
!
[
1
,
2
,
4
,
8
].
includes
(
lowres
)){
lowres
=
4
;
}
...
...
@@ -692,4 +692,4 @@ var Elphel = {
console
.
log
(
"Test message from elphel.js: ok"
);
}
}
\ No newline at end of file
}
src/jp4-canvas/jp4-canvas.html
View file @
2d52ff11
...
...
@@ -7,12 +7,12 @@
<body>
<table>
<tr>
<td><div
id=
'test1'
></div></td>
<td><div
id=
'test2'
></div></td>
<td
valign=
'top'
><div
id=
'test1'
></div></td>
<td
valign=
'top'
><div
id=
'test2'
></div></td>
</tr>
<tr>
<td><div
id=
'test3'
></div></td>
<td><div
id=
'test4'
></div></td>
<td
valign=
'top'
><div
id=
'test3'
></div></td>
<td
valign=
'top'
><div
id=
'test4'
></div></td>
</tr>
</table>
<script
src=
"js/elphel.js"
></script>
...
...
src/jp4-canvas/jp4-canvas.js
View file @
2d52ff11
...
...
@@ -26,10 +26,10 @@
*/
$
(
function
(){
var
t1
=
$
(
"#test1"
).
jp4
({
ip
:
location
.
host
,
port
:
2323
,
width
:
600
,
fast
:
true
,
lowres
:
4
});
var
t2
=
$
(
"#test2"
).
jp4
({
ip
:
location
.
host
,
port
:
2324
,
width
:
600
,
fast
:
true
,
lowres
:
4
});
var
t3
=
$
(
"#test3"
).
jp4
({
ip
:
location
.
host
,
port
:
2325
,
width
:
600
,
fast
:
true
,
lowres
:
4
});
var
t4
=
$
(
"#test4"
).
jp4
({
ip
:
location
.
host
,
port
:
2326
,
width
:
600
,
fast
:
true
,
lowres
:
4
});
let
t1
=
$
(
"#test1"
).
jp4
({
src
:
"http://"
+
location
.
host
+
":"
+
2323
+
"/img"
,
width
:
600
,
fast
:
true
,
lowres
:
2
,
debug
:
false
,
refresh
:
false
});
let
t2
=
$
(
"#test2"
).
jp4
({
src
:
"http://"
+
location
.
host
+
":"
+
2324
+
"/img"
,
width
:
600
,
fast
:
true
,
lowres
:
2
,
debug
:
false
,
refresh
:
false
});
let
t3
=
$
(
"#test3"
).
jp4
({
src
:
"http://"
+
location
.
host
+
":"
+
2325
+
"/img"
,
width
:
600
,
fast
:
true
,
lowres
:
2
,
debug
:
false
,
refresh
:
false
});
let
t4
=
$
(
"#test4"
).
jp4
({
src
:
"http://"
+
location
.
host
+
":"
+
2326
+
"/img"
,
width
:
600
,
fast
:
true
,
lowres
:
2
,
debug
:
false
,
refresh
:
false
});
});
src/jp4-canvas/jquery-jp4.js
View file @
2d52ff11
This diff is collapsed.
Click to expand it.
src/jp4-canvas/webworker.js
View file @
2d52ff11
importScripts
(
'elphel.js'
);
self
.
onmessage
=
function
(
e
)
{
var
W
=
e
.
data
.
width
;
var
H
=
e
.
data
.
height
;
var
Mosaic
=
e
.
data
.
mosaic
;
var
Format
=
e
.
data
.
format
;
var
settings
=
e
.
data
.
settings
;
var
Pixels
=
new
Uint8Array
(
e
.
data
.
pixels
);
if
(
settings
.
lowres
==
0
){
var
reorderedPixels
=
Elphel
.
Pixels
.
reorderBlocksJPx
(
Pixels
,
W
,
H
,
Format
,
Mosaic
,
settings
.
fast
);
//reorder first then downscale
if
(
settings
.
fast
){
W
=
W
/
2
;
H
=
H
/
2
;
onmessage
=
async
(
e
)
=>
{
let
W
=
e
.
data
.
width
;
let
H
=
e
.
data
.
height
;
let
Mosaic
=
e
.
data
.
mosaic
;
let
Format
=
e
.
data
.
format
;
let
settings
=
e
.
data
.
settings
;
let
Pixels
=
new
Uint8Array
(
e
.
data
.
pixels
);
let
reorderedPixels
;
if
(
settings
.
lowres
==
0
){
reorderedPixels
=
Elphel
.
Pixels
.
reorderBlocksJPx
(
Pixels
,
W
,
H
,
Format
,
Mosaic
,
settings
.
fast
);
//reorder first then downscale
if
(
settings
.
fast
){
W
=
W
/
2
;
H
=
H
/
2
;
}
}
else
{
reorderedPixels
=
await
Elphel
.
Pixels
.
reorderBlocksJP4_lowres
(
Pixels
,
W
,
H
,
Format
,
Mosaic
,
settings
.
lowres
);
W
=
W
/
2
;
H
=
H
/
2
;
}
}
else
{
var
reorderedPixels
=
Elphel
.
Pixels
.
reorderBlocksJP4_lowres
(
Pixels
,
W
,
H
,
Format
,
Mosaic
,
settings
.
lowres
);
W
=
W
/
2
;
H
=
H
/
2
;
}
Elphel
.
Pixels
.
applySaturation
(
reorderedPixels
,
W
,
H
,
2
);
postMessage
({
width
:
W
,
height
:
H
,
pixels
:
reorderedPixels
.
buffer
},[
reorderedPixels
.
buffer
]);
Elphel
.
Pixels
.
applySaturation
(
reorderedPixels
,
W
,
H
,
2
);
//Elphel.test();
this
.
close
();
postMessage
({
width
:
W
,
height
:
H
,
pixels
:
reorderedPixels
.
buffer
},[
reorderedPixels
.
buffer
]);
};
\ No newline at end of file
//Elphel.test();
this
.
close
();
};
src/jp4-viewer/jp4-viewer.js
View file @
2d52ff11
...
...
@@ -65,7 +65,7 @@ function handleImage(e) {
//console.log(SETTINGS.width);
view
.
jp4
({
image
:
myimg
,
fromhtmlinput
:
true
,
width
:
SETTINGS
.
width
,
fast
:
true
,
lowres
:
SETTINGS
.
quality
,
webworker_path
:
"../js"
});
view
.
jp4
({
src
:
myimg
,
fromhtmlinput
:
true
,
width
:
SETTINGS
.
width
,
fast
:
true
,
lowres
:
SETTINGS
.
quality
,
webworker_path
:
"../js"
});
//view.jp4({image:"test.jp4", input: false, width:1200,fast:true, lowres:1});
$
(
"#jp4view"
).
append
(
view
);
...
...
src/multicam/multicam.js
View file @
2d52ff11
...
...
@@ -477,8 +477,9 @@ function refresh_previews(){
//console.log("preview does not exist");
var
jp4prev
=
elem
.
find
(
".port_preview[index="
+
j
+
"]"
);
var
preview
=
jp4prev
.
jp4
({
ip
:
cam
.
ip
,
port
:
cam
.
ports
[
j
].
port
,
//ip: cam.ip,
//port: cam.ports[j].port,
src
:
"http://"
+
cam
.
ip
+
":"
+
cam
.
ports
[
j
].
port
+
"/img"
,
width
:
200
,
fast
:
true
,
lowres
:
4
,
...
...
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