diff --git a/canavs-api/basic-image-example/.vscode/settings.json b/canavs-api/basic-image-example/.vscode/settings.json index e695fc7..601efbd 100644 --- a/canavs-api/basic-image-example/.vscode/settings.json +++ b/canavs-api/basic-image-example/.vscode/settings.json @@ -7,5 +7,5 @@ "prettier.singleQuote": true, "prettier.semi": true, "editor.formatOnSave": true, - "cSpell.words": [] + "cSpell.words": ["tileset"] } diff --git a/canavs-api/basic-image-example/src/encoded-image.js b/canavs-api/basic-image-example/src/encoded-image.js new file mode 100644 index 0000000..9b629c0 --- /dev/null +++ b/canavs-api/basic-image-example/src/encoded-image.js @@ -0,0 +1,2 @@ +export const encodedImage = + ''; diff --git a/canavs-api/basic-image-example/src/main.js b/canavs-api/basic-image-example/src/main.js index a44833b..995743d 100644 --- a/canavs-api/basic-image-example/src/main.js +++ b/canavs-api/basic-image-example/src/main.js @@ -1,3 +1,40 @@ +import { encodedImage } from './encoded-image.js'; + +/** + * @param {string} src + * @returns {Promise} + */ +function loadImage(src) { + return new Promise((resolve) => { + const img = new Image(); + img.addEventListener( + 'load', + () => { + resolve(img); + }, + false + ); + img.src = src; + }); +} + +/** + * @returns {Promise} + */ +function getEncodedImage() { + return new Promise((resolve) => { + const img = new Image(); + img.addEventListener( + 'load', + () => { + resolve(img); + }, + false + ); + img.src = encodedImage; + }); +} + void (async function () { const canvas = document.getElementById('game'); if (!(canvas instanceof HTMLCanvasElement)) { @@ -10,5 +47,18 @@ void (async function () { return; } - // TODO: add main logic + const img = await loadImage('assets/grunge-tileset.png'); + // const img = await getEncodedImage(); + + // example of drawing image directly + // drawImage(image, dx, dy) + ctx.drawImage(img, 0, 0); + + // example of scaling by providing width and height on destination + // drawImage(image, dx, dy, dWidth, dHeight) + // ctx.drawImage(img, 0, 0, img.width * 1.5, img.height * 1.5); + + // example of slicing image by providing the source image values and destination canvas details + // drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight) + // ctx.drawImage(img, 200, 0, 200, 160, 100, 0, 200, 160); })();