Skip to content

Commit

Permalink
Merge branch 'dev'
Browse files Browse the repository at this point in the history
  • Loading branch information
bleeptrack committed Sep 17, 2024
2 parents 62dc370 + 1cbda9e commit 8449516
Show file tree
Hide file tree
Showing 6 changed files with 115 additions and 13 deletions.
Binary file added .github/examples.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -25,3 +25,4 @@ templates/index_.html
static/drawing.js

.README.md.kate-swp
tinqta.code-workspace
3 changes: 3 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,9 @@ Afterwards you can start tinqta with
tinqta is still under heavy development and will likely change a lot!
More info on usage coming soon!

## 🎨 Examples
![examples](https://github.com/bleeptrack/tinqta/blob/main/.github/examples.png?raw=true)

## 👀 Projects using tinqta
- [AI Doodles](https://www.youtube.com/playlist?list=PLSV1FvtNZeQF81iLqAgOjbA1cLRTSrcFl) by [bleeptrack](htttps://www.bleeptrack.de)
- [PatternPortrait](https://bleeptrack.de/projects/patternportrait/) by [bleeptrack](htttps://www.bleeptrack.de)
Expand Down
6 changes: 4 additions & 2 deletions static/ProgressBar.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ export class ProgressBar extends HTMLElement {
<div id="bar">
<div id="progress" class="scribble"></div>
<span id="label"></span>
<span id="label">starting...</span>
</div>
`;
Expand All @@ -54,7 +54,9 @@ export class ProgressBar extends HTMLElement {
}

setPercentage(percentage, label){
this.shadow.getElementById("label").innerHTML = label
if(label){
this.shadow.getElementById("label").innerHTML = label
}
for(let rule of this.shadow.styleSheets[this.shadow.styleSheets.length-1].cssRules){
if(rule.selectorText == "#progress::after" ){
rule.style.width = `calc(${percentage}% - 1px)`
Expand Down
108 changes: 98 additions & 10 deletions static/VectorizerCanvas.js
Original file line number Diff line number Diff line change
Expand Up @@ -269,6 +269,7 @@ export class VectorizerCanvas extends HTMLElement {
activateImage(e){

this.shadow.getElementById("container").innerHTML = `
<h1 id="background-remover-title">Please hang on while we remove the background</h1>
<div id="canvas-container"></div>
<img id="image"></img>
<canvas id="edge-canvas"></canvas>
Expand All @@ -283,21 +284,70 @@ export class VectorizerCanvas extends HTMLElement {
//type: 'foreground' | 'background' | 'mask'; // The output type. (Default "foreground")
}
}
console.log(URL.createObjectURL(e.target.files.item(0)))
removeBackground(URL.createObjectURL(e.target.files.item(0)), bgRemoveConfig).then((blob) => {
// The result is a blob encoded as PNG. It can be converted to an URL to be used as HTMLImage.src
const url = URL.createObjectURL(blob);

img.src = url
console.log(url)
this.video = img

// Create a new FileReader
const reader = new FileReader();

// Set up the FileReader onload function
reader.onload = (event) => {
const imgTmp = new Image();
imgTmp.onload = () => {
let scaledImg = this.scaleImageTo1080p(imgTmp)
removeBackground(scaledImg, bgRemoveConfig).then((blob) => {
// The result is a blob encoded as PNG. It can be converted to an URL to be used as HTMLImage.src
const url = URL.createObjectURL(blob);

img.src = url
console.log(url)
this.video = img

})
};
imgTmp.src = event.target.result;
};
// Read the first file from the input
if(e.target){
reader.readAsDataURL(e.target.files.item(0));
}else{
console.log("no file selected", e)
const imgTmp = new Image();
imgTmp.onload = () => {
let scaledImg = this.scaleImageTo1080p(imgTmp)
removeBackground(scaledImg, bgRemoveConfig).then((blob) => {
// The result is a blob encoded as PNG. It can be converted to an URL to be used as HTMLImage.src
const url = URL.createObjectURL(blob);

img.src = url
console.log(url)
this.video = img

})
};

})
// Create a canvas element to draw the video frame
const canvas = document.createElement('canvas');
const context = canvas.getContext('2d');

// Set canvas dimensions to match the video frame
canvas.width = this.vidw
canvas.height = this.vidh

// Draw the current video frame to the canvas
context.drawImage(this.video, 0, 0, canvas.width, canvas.height);

// Convert the canvas content to a data URL
const dataURL = canvas.toDataURL('image/png');

// Use this data URL as the source for our image
imgTmp.src = dataURL;
}





img.addEventListener("load", ()=>{

this.shadow.getElementById("background-remover-title").remove()

this.vidw = img.naturalWidth
this.vidh = img.naturalHeight
Expand Down Expand Up @@ -330,6 +380,39 @@ export class VectorizerCanvas extends HTMLElement {


}

scaleImageTo1080p(img) {
console.log("img", img)
const MAX_WIDTH = 1920;
const MAX_HEIGHT = 1080;
let width = img.width;
let height = img.height;


// Calculate the scaling factor
if (width > MAX_WIDTH || height > MAX_HEIGHT) {
const widthRatio = MAX_WIDTH / width;
const heightRatio = MAX_HEIGHT / height;
const scaleFactor = Math.min(widthRatio, heightRatio);

width = Math.floor(width * scaleFactor);
height = Math.floor(height * scaleFactor);
}

// Create a canvas to draw the scaled image
const canvas = document.createElement('canvas');
canvas.width = width;
canvas.height = height;
const ctx = canvas.getContext('2d');

// Draw the image at the new size
ctx.drawImage(img, 0, 0, width, height);

// Create and return a new image from the canvas
const scaledImg = canvas.toDataURL();
console.log("img scaled", scaledImg)
return scaledImg;
}

activateWebcam(){
if (navigator.mediaDevices.getUserMedia) {
Expand All @@ -342,6 +425,7 @@ export class VectorizerCanvas extends HTMLElement {
<div id="canvas-container"></div>
<video id="webcam"></video>
<canvas id="edge-canvas"></canvas>
<button id="stop-webcam" class="scribble">take photo</button>
`

this.video = this.shadow.getElementById("webcam")
Expand Down Expand Up @@ -373,6 +457,10 @@ export class VectorizerCanvas extends HTMLElement {
console.log(navigator.mediaDevices.getUserMedia)
})

this.shadow.getElementById("stop-webcam").addEventListener("click", () => {
paper.view.onFrame = () => {}
this.activateImage(this.video)
})



Expand Down
10 changes: 9 additions & 1 deletion static/WebcamGenerator.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,18 +74,21 @@ export class WebcamGenerator extends HTMLElement {
#settings{
position: absolute;
bottom: 0;
left: 0;
background: rgba(255,255,255,0.5);
width: 100%;
height: 20%;
flex-direction: column;
justify-content: space-evenly;
align-items: center;
display: none;
font-family: 'monospace';
}
#right{
background-color: grey;
}
progress-bar{
width: 100%;
width: 95%;
}
svg{
Expand Down Expand Up @@ -113,6 +116,10 @@ export class WebcamGenerator extends HTMLElement {
<vectorizer-canvas id="vec"></vectorizer-canvas>
</div>
<div id="settings">
<p id="settings-description">
Adjust the edge detection settings to fine-tune the vectorization process.
Adjust min and max thresholds to control edge sensitivity.
</p>
<div id="settings-edge">
<label for="edge-detail">Edge Detail:</label>
<input type="range" min="1" max="8" value="2" class="slider" id="edge-detail">
Expand Down Expand Up @@ -197,6 +204,7 @@ export class WebcamGenerator extends HTMLElement {
})
this.shadow.getElementById("vec").replaceWith(this.svg)

this.shadow.getElementById("settings-description").textContent = "Adjust colors, style and animation length. Download SVG or copy the HTML Code to your clipboard."

let settingsEdge = this.shadow.getElementById("settings-edge")
settingsEdge.style.display = "flex"
Expand Down

0 comments on commit 8449516

Please sign in to comment.