ThumbMakermain.tsx27 matches
1/**
2* This application creates a thumbnail maker using Hono for server-side routing and client-side JavaScript for image processing.
3* It allows users to upload images, specify output options, and generate a composite thumbnail image.
4* The app uses the HTML5 Canvas API for image manipulation and supports drag-and-drop functionality.
5*
6* The process is divided into two steps:
7* 1. Generating thumbnails: Users choose thumbnail size options and create individual thumbnails.
8* 2. Rendering: Users can create and export the final composite image with options for format and quality.
9* This two-step process allows changing format or quality without re-rendering the entire canvas.
10*
33<h1>Thumbnail Maker</h1>
34<div id="dropZone">
35<p>π· Drag & drop images here or click to select</p>
36<input type="file" id="fileInput" multiple accept="image/*">
37</div>
38<div id="thumbnailOptions">
57Output Format:
58<select id="outputFormat">
59<option value="image/png">PNG</option>
60<option value="image/jpeg">JPEG</option>
61<option value="image/webp">WebP</option>
62</select>
63</label><br>
74<button id="downloadMetadataBtn">Download Metadata</button>
75</div>
76<div id="imagePreview"></div>
77</div>
78</body>
138select {
139appearance: none;
140background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M10.293 3.293L6 7.586 1.707 3.293A1 1 0 00.293 4.707l5 5a1 1 0 001.414 0l5-5a1 1 0 10-1.414-1.414z' fill='%23333'/%3E%3C/svg%3E");
141background-repeat: no-repeat;
142background-position: right 10px center;
204}
205206#imagePreview {
207margin-top: 20px;
208text-align: center;
209}
210211#imagePreview img {
212max-width: 100%;
213height: auto;
231const keepAspectRatio = document.getElementById('keepAspectRatio');
232const thumbWidth = document.getElementById('thumbWidth');
233const imagePreview = document.getElementById('imagePreview');
234const thumbnailOptions = document.getElementById('thumbnailOptions');
235const renderOptions = document.getElementById('renderOptions');
249renderOptions.style.display = 'none';
250downloadSection.style.display = 'none';
251imagePreview.innerHTML = '';
252thumbnailCanvas = null;
253thumbnailMetadata = null;
274event.preventDefault();
275dropZone.classList.remove('drag-over');
276files = Array.from(event.dataTransfer.files).filter(file => file.type.startsWith('image/'));
277resetToStep1();
278});
289progressBar.value = 0;
290291const image0 = await getImage(files[0]);
292const cols = Math.ceil(Math.sqrt(files.length));
293const rows = Math.ceil(files.length / cols);
294const tHeight = parseInt(thumbHeight.value);
295let tWidth = keepAspectRatio.checked
296? Math.floor(tHeight / image0.height * image0.width)
297: parseInt(thumbWidth.value);
298300const canvasHeight = rows * tHeight;
301302image0.revoke();
303304thumbnailCanvas = new OffscreenCanvas(canvasWidth, canvasHeight);
310const row = Math.floor(i / cols);
311312const img = await getImage(file);
313ctx.drawImage(img, col * tWidth, row * tHeight, tWidth, tHeight);
314img.revoke();
315343const blob = await thumbnailCanvas.convertToBlob({
344type: outputFormat.value,
345quality: outputFormat.value !== 'image/png' ? parseFloat(outputQuality.value) : undefined
346});
347351downloadSection.style.display = 'flex';
352353// Display the generated image
354const img = document.createElement('img');
355img.src = url;
356imagePreview.innerHTML = '';
357imagePreview.appendChild(img);
358359progressBar.style.display = 'none';
375});
376377function getImage(file) {
378return new Promise((resolve) => {
379const url = URL.createObjectURL(file);
380const img = new Image();
381img.revoke = () => URL.revokeObjectURL(url);
382img.onload = () => resolve(img);
135<link
136rel="icon"
137href=""
138/>
139<title>rss viewer</title>
setTidbytImagemain.tsx4 matches
7];
89export async function setTidbytImage({ image }: {
10image: string;
11}) {
12const apiKey = Deno.env.get("tidbyt_apikey");
21body: JSON.stringify({
22"deviceID": id,
23"image": image,
24"installationID": "custom",
25"background": false,
28);
29if (!res.ok) {
30console.error("Error setting tidbyt image:", res.status, await res.text());
31}
32}
patchedFeedExtractormain.tsx1 match
348}
349});
350const optionalProps = "source category enclosure author image".split(" ");
351optionalProps.forEach((key) => {
352if (hasProperty(item2, key)) {
blob_adminREADME.md1 match
3This is a lightweight Blob Admin interface to view and debug your Blob data.
45
67Use this button to install the val:
telegramDalleBotmain.tsx5 matches
1import { textToImageDalle } from "https://esm.town/v/hootz/textToImageDalle";
2import { telegramSendMessage } from "https://esm.town/v/vtdocs/telegramSendMessage?v=5";
3import { telegramSendPhoto } from "https://esm.town/v/vtdocs/telegramSendPhoto?v=1";
20telegramSendMessage(
21process.env.telegramDalleBotToken,
22{ chat_id: chatId, text: "send prompt, get an image!" },
23);
24return;
25}
26// otherwise, generate an image!
27try {
28const imageURL = (await textToImageDalle(
29process.env.openai,
30text,
36process.env.telegramDalleBotToken,
37// caption is limited to 1024 characters
38{ chat_id: chatId, photo: imageURL, caption: text.slice(0, 1024) },
39);
40}
telegramDalleBotREADME.md1 match
1# Telegram DALLE Bot
23A personal telegram bot you can message to create images with OpenAI's [DALLE](https://openai.com/dall-e-2) β¨
45
tidbytCirclemain.tsx3 matches
6const { default: Jimp } = await import("npm:jimp@0");
7const img = await new Jimp(size, size);
8for (const { x, y, idx, image } of img.scanIterator(0, 0, size, size)) {
9const dx = x - size / 2 + 0.5;
10const dy = y - size / 2 + 0.5;
12if (d <= size / 2) {
13if (typeof border === "number" && d > (size / 2 - 1)) {
14image.setPixelColor(border, x, y);
15}
16else if (typeof fill === "number") {
17image.setPixelColor(fill, x, y);
18}
19}
8import Jimp from "npm:jimp@0";
910export async function createTidbytWorkoutsImage(icons: WorkoutIcon[]) {
11const headerUrl = "https://art.pixilart.com/sr2c714c74a22aws3.png";
12const weekdaysUrl = "https://art.pixilart.com/sr22f1df42b42aws3.png";
rabbitstreamUtilsmain.tsx1 match
55}
56export async function getWasm() {
57const req = await fetch("https://rabbitstream.net/images/loading.png?v=0.6", {
58"headers": {
59"Referrer-Policy": "strict-origin-when-cross-origin",