feat: deviceorientation to control lensflare
This commit is contained in:
parent
f41f1ea4b2
commit
49707ede24
24
index.html
24
index.html
|
@ -72,23 +72,17 @@
|
||||||
<!-- autocomplete off prevents browsers from remebering the value on page reloads -->
|
<!-- autocomplete off prevents browsers from remebering the value on page reloads -->
|
||||||
<form autocomplete="off">
|
<form autocomplete="off">
|
||||||
<div class="buttons">
|
<div class="buttons">
|
||||||
<button id="save" class="button is-primary">
|
<button class="button is-primary save-image">
|
||||||
Save Image
|
Save Image
|
||||||
</button>
|
</button>
|
||||||
<button id="share" class="button is-secondary">
|
<button class="button is-secondary share-image">
|
||||||
<i class="fa-solid fa-share-from-square fa-fw mr-1"></i>
|
<i class="fa-solid fa-share-from-square fa-fw mr-1"></i>
|
||||||
Share
|
Share
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<!--
|
<button class="button is-medium is-fullwidth lensflare">
|
||||||
<label class="label">
|
|
||||||
Use Gyroscope
|
|
||||||
<input type="checkbox" class="is-pulled-right">
|
|
||||||
</label>
|
|
||||||
-->
|
|
||||||
<button id="lensflare" class="button is-medium is-fullwidth">
|
|
||||||
Lensflare
|
Lensflare
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
@ -236,13 +230,21 @@
|
||||||
|
|
||||||
<!-- autocomplete off prevents browsers from remebering the value on page reloads -->
|
<!-- autocomplete off prevents browsers from remebering the value on page reloads -->
|
||||||
<form autocomplete="off">
|
<form autocomplete="off">
|
||||||
<button id="save" class="button is-primary">
|
<div class="buttons">
|
||||||
|
<button class="button is-primary save-image">
|
||||||
Save Image
|
Save Image
|
||||||
</button>
|
</button>
|
||||||
<button id="share" class="button is-secondary">
|
<button class="button is-secondary share-image">
|
||||||
<i class="fa-solid fa-share-from-square fa-fw mr-1"></i>
|
<i class="fa-solid fa-share-from-square fa-fw mr-1"></i>
|
||||||
Share
|
Share
|
||||||
</button>
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="field">
|
||||||
|
<button class="button is-medium is-fullwidth lensflare">
|
||||||
|
Lensflare
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
<p class="menu-label">
|
<p class="menu-label">
|
||||||
Color Correction
|
Color Correction
|
||||||
|
|
30
main.js
30
main.js
|
@ -32,10 +32,16 @@ document.addEventListener("DOMContentLoaded", function() {
|
||||||
document.getElementById("cheese").addEventListener("click", take_picture);
|
document.getElementById("cheese").addEventListener("click", take_picture);
|
||||||
document.getElementById("upload-image").addEventListener("change", upload_image)
|
document.getElementById("upload-image").addEventListener("change", upload_image)
|
||||||
|
|
||||||
document.getElementById("save").addEventListener("click", save_image)
|
for (let element of document.getElementsByClassName("save-image")) {
|
||||||
document.getElementById("share").addEventListener("click", share_image)
|
element.addEventListener("click", save_image)
|
||||||
|
}
|
||||||
|
for (let element of document.getElementsByClassName("share-image")) {
|
||||||
|
element.addEventListener("click", share_image)
|
||||||
|
}
|
||||||
|
|
||||||
document.getElementById("lensflare").addEventListener("click", function(event) {
|
for (let element of document.getElementsByClassName("lensflare")) {
|
||||||
|
element.addEventListener("click", function(event) {
|
||||||
|
event.preventDefault();
|
||||||
lensflare_active = !lensflare_active;
|
lensflare_active = !lensflare_active;
|
||||||
if (lensflare_active) {
|
if (lensflare_active) {
|
||||||
event.target.classList.add("is-primary");
|
event.target.classList.add("is-primary");
|
||||||
|
@ -44,6 +50,7 @@ document.addEventListener("DOMContentLoaded", function() {
|
||||||
}
|
}
|
||||||
draw(true);
|
draw(true);
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
document.getElementById("viewport").addEventListener("mousemove", function(event) {
|
document.getElementById("viewport").addEventListener("mousemove", function(event) {
|
||||||
if (event.buttons === 1 && lensflare_active) {
|
if (event.buttons === 1 && lensflare_active) {
|
||||||
|
@ -54,6 +61,23 @@ document.addEventListener("DOMContentLoaded", function() {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
window.addEventListener("deviceorientation", function(event) {
|
||||||
|
if (lensflare_active) {
|
||||||
|
cursor.x = event.gamma / 360 * 4;
|
||||||
|
cursor.y = (event.beta - 90) / 360 * 4;
|
||||||
|
console.log(cursor);
|
||||||
|
// draw(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
function animation() {
|
||||||
|
if (lensflare_active) {
|
||||||
|
draw(true);
|
||||||
|
}
|
||||||
|
requestAnimationFrame(animation)
|
||||||
|
};
|
||||||
|
animation();
|
||||||
|
|
||||||
window.addEventListener("resize", () => draw(true))
|
window.addEventListener("resize", () => draw(true))
|
||||||
|
|
||||||
video.addEventListener("canplay", function() {
|
video.addEventListener("canplay", function() {
|
||||||
|
|
Loading…
Reference in a new issue