Skip to content

Commit

Permalink
Merge pull request Samsung#2 from D5MI/feature/pose-object-mapping
Browse files Browse the repository at this point in the history
feat: pose & object command register
  • Loading branch information
Garo-o authored Sep 22, 2022
2 parents 954db0a + a14a630 commit eed6144
Showing 1 changed file with 139 additions and 76 deletions.
215 changes: 139 additions & 76 deletions cocoSsd.html
Original file line number Diff line number Diff line change
Expand Up @@ -3,20 +3,20 @@
<head>
<style>
/* 이미지에 캔버스를 겹쳐서 그릴때는 아래 주석 해제 */

/* #frame > {
display: block;
margin : auto;
} */

h2 {
margin-top : 15px;
margin-top: 15px;
margin-right: auto;
margin-left: auto;
text-align: center;
}

#regi-form{
#regi-form {
margin-top: 0%;
}

Expand All @@ -25,63 +25,76 @@
vertical-align: bottom;
} */

#frame > video {
#frame>video {
position: absolute;
border: 8px solid rgb(15, 195, 39);
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
#frame > canvas{

#frame>canvas {
position: absolute;
border: 1px solid gray;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}

</style>
</head>

<body>
<div id = "title">

<div id="title">
<h2>Object detection display</h2>
</div>

<div style ="min-height: 800px;">
<div id="frame">
<video id="video" width="640" height="480" autoplay muted playsinline></video>
<canvas id="canvas"></canvas>
</div>

<div id ="detected-result-message">
<h3 style='text-align: left; margin : 0px; '>Detected objects</h3></br>
<h4>INDEX Objects register</h4>
<form action="" id="regi-form">
<label for="test">test</label>
<input type="text" id="test" value="hello">
</form>
<button id = "captrue-btn">register</button>
</div>
<div style="min-height: 800px;">
<div id="frame">
<video id="video" width="640" height="480" autoplay muted playsinline></video>
<canvas id="canvas"></canvas>
</div>

<div id="detected-result-message">
<h3 style='text-align: left; margin : 0px; '>Detected objects</h3></br>
<h4>INDEX Objects register</h4>
<form action="" id="regi-form">
<label for="test">test</label>
<input type="text" id="test" value="hello">
</form>
<button id="captrue-btn">register</button>
<div>
<button id="pose-object-btn">pose-object mapping</button>
<div id="pose-object-mapping">

</div>
<button id="pose-object-mapping-btn" style="display:none;">regist</button>
</div>
</div>
</div>


<div align="center" style="min-height: 100px;">
<br>
<a href="https://github.com/5FNSaaS">
<img style="width:15px"
src="" />
D5MI
</a> |
<a href="https://github.com/rootkwak528">Seunghoon Park</a> | <a href="https://github.com/eona1301">Youngjin Choi</a>
| <a href="https://github.com/whgusalsdl">Juseong Hong</a> | <a href="https://github.com/483759">Sangwoo Han</a> |
<a href="https://github.com/steven9408">Donghyun Han</a> | <a href="https://github.com/steven9408">Yongwoong Kim</a><br>
<a href="https://github.com/rootkwak528">Seunghoon Park</a> | <a href="https://github.com/eona1301">Youngjin
Choi</a>
| <a href="https://github.com/whgusalsdl">Juseong Hong</a> | <a href="https://github.com/483759">Sangwoo Han</a>
|
<a href="https://github.com/steven9408">Donghyun Han</a> | <a href="https://github.com/steven9408">Yongwoong
Kim</a><br>
</div>


<script src="https://cdn.jsdelivr.net/npm/@tensorflow/[email protected]/dist/tf.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/@tensorflow-models/[email protected]/dist/coco-ssd.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js" integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js"
integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM"
crossorigin="anonymous"></script>
<script src="https://code.jquery.com/jquery-1.12.4.js"></script>

<script>
Expand All @@ -103,20 +116,69 @@ <h4>INDEX Objects register</h4>
const _form = document.getElementById("regi-form")


/*
* 거루가 쓰는 공간 1
*/


function validation(predictions){
for(i = 0; i < predictions.length; i++){
if(predictions[i].class === "person"){
/*
* garo start
*/
let savedPose = [{name:'seat'},{name:'armup'}]
let savedObject = [{name:'person'},{name:'chair'},{name:'cellphone'},{name:'cup'}]
document.getElementById('pose-object-btn').addEventListener('click', () => {
let area = document.getElementById('pose-object-mapping')
let html = `
<select name="pose" id="pose">
<option value="null" selected>null</option>`

savedPose.forEach(pose=>{
html += `<option value="`+pose.name+`">`+pose.name+`</option>`
})

html += `</select>
<select name="object" id="object">
<option value="null" selected>null</option>`

savedObject.forEach(object=>{
html += `<option value="`+object.name+`">`+object.name+`</option>`
})
html += ` </select>
<input type="text" id="pose-object-name">
`

area.innerHTML = html

document.getElementById('pose-object-mapping-btn').setAttribute('style', '')
})

document.getElementById('pose-object-mapping-btn').addEventListener('click', ()=>{
let nodes = document.getElementById('pose-object-mapping').children
let pose = getVal(nodes.pose);
let object = getVal(nodes.object);
let value = document.getElementById('pose-object-name').value

function getVal(node){
let res;
for(let i=0; i<node.options.length; i++){
if(node.options[i].selected == true){
res = node.options[i].value;
}
}
return res
}
console.log({pose, object, value});
registerWebSocket.send(JSON.stringify({pose, object, value}));
})

/*
* garo end
*/

function validation(predictions) {
for (i = 0; i < predictions.length; i++) {
if (predictions[i].class === "person") {
return true;
}
}
}
return false;
}

navigator.mediaDevices.getUserMedia({ video: true, audio: false })
.then(function (stream) {
video.srcObject = stream;
Expand All @@ -129,12 +191,12 @@ <h4>INDEX Objects register</h4>
model.detect(canvas).then(predictions => {

objects = [...predictions]




if(validation(predictions)){
dataWebSocket.send(JSON.stringify({detect : predictions}));


if (validation(predictions)) {
dataWebSocket.send(JSON.stringify({ detect: predictions }));
}

canvas.width = video.width;
Expand All @@ -157,44 +219,45 @@ <h4>INDEX Objects register</h4>
}
});

/*
* 거루가 쓰는 공간 2
*/


setInterval(() => {
dataWebSocket.send(JSON.stringify({log : objects}))
objects.forEach((element) => {
if(!detected.includes(element["class"])){
detected.push(element["class"]);
let tmpNode = document.createElement('div');
let tmpSpan = document.createElement('span');
let tmpInput = document.createElement('input');
let tmpString = document.createTextNode(detectedCnt + " " + element["class"]);

//tmpNode.style.cssText = "display : flex; justify-content: left; margin-top : .25rem; margin-bottom : .25rem;"
tmpInput.type="checkbox"
tmpInput.id=element["class"]
tmpInput.value=element["class"]

tmpSpan.appendChild(tmpString);
tmpNode.appendChild(tmpSpan);
tmpNode.appendChild(tmpInput);
_form.insertAdjacentElement('beforeend', tmpNode);
detectedCnt += 1
}
});


/*
* 거루가 쓰는 공간 2
*/


setInterval(() => {
dataWebSocket.send(JSON.stringify({ log: objects }))

objects.forEach((element) => {
if (!detected.includes(element["class"])) {
detected.push(element["class"]);

let tmpNode = document.createElement('div');
let tmpSpan = document.createElement('span');
let tmpInput = document.createElement('input');
let tmpString = document.createTextNode(detectedCnt + " " + element["class"]);

//tmpNode.style.cssText = "display : flex; justify-content: left; margin-top : .25rem; margin-bottom : .25rem;"
tmpInput.type = "checkbox"
tmpInput.id = element["class"]
tmpInput.value = element["class"]

tmpSpan.appendChild(tmpString);
tmpNode.appendChild(tmpSpan);
tmpNode.appendChild(tmpInput);

_form.insertAdjacentElement('beforeend', tmpNode);
detectedCnt += 1
}
});
},
1000);
1000);

registerBtn.addEventListener("click", function(){
registerBtn.addEventListener("click", function () {
registerWebSocket.send(JSON.stringify(detected.filter((element) => {
return document.getElementById(element).checked})));
return document.getElementById(element).checked
})));
});

</script>
Expand Down

0 comments on commit eed6144

Please sign in to comment.