Skip to content

Commit

Permalink
Fix image render area
Browse files Browse the repository at this point in the history
* Fix images not being fully rendered when sizeUnits is not em

* Fix incorrect scaling of images using em sizeUnits

* Make tests happy

* Set style width and height to 100% to render correctly in anki

* Update tests

<rikaitan.link>NTg1ODU0ZDZhODQ0MTQ5YWY3ZTU3ZTM0MDU2NDQwZDdiOGEwYWJlNQo=</rikaitan.link>
  • Loading branch information
jason-ojisan committed Dec 26, 2024
1 parent dc0ec9b commit 39d8d09
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 21 deletions.
15 changes: 6 additions & 9 deletions ext/js/display/structured-content-generator.js
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,7 @@ export class StructuredContentGenerator {

if (typeof border === 'string') { imageContainer.style.border = border; }
if (typeof borderRadius === 'string') { imageContainer.style.borderRadius = borderRadius; }
imageContainer.style.width = `${usedWidth}em`;
if (typeof title === 'string') {
imageContainer.title = title;
}
Expand All @@ -124,17 +125,13 @@ export class StructuredContentGenerator {
const image = this._contentManager instanceof DisplayContentManager ?
/** @type {HTMLCanvasElement} */ (this._createElement('canvas', 'gloss-image')) :
/** @type {HTMLImageElement} */ (this._createElement('img', 'gloss-image'));
if (sizeUnits === 'em' && (hasPreferredWidth || hasPreferredHeight)) {
const emSize = 14; // We could Number.parseFloat(getComputedStyle(document.documentElement).fontSize); here for more accuracy but it would cause a layout and be extremely slow; possible improvement would be to calculate and cache the value
const scaleFactor = 2 * window.devicePixelRatio;
image.style.width = `${usedWidth}em`;
image.style.height = `${usedWidth * invAspectRatio}em`;
image.width = usedWidth * emSize * scaleFactor;
} else {
image.width = usedWidth;
}
image.width = width;
image.height = image.width * invAspectRatio;

// Anki will not render images correctly without specifying to use 100% width and height
image.style.width = '100%';
image.style.height = '100%';

imageContainer.appendChild(image);

if (this._contentManager instanceof DisplayContentManager) {
Expand Down
Loading

0 comments on commit 39d8d09

Please sign in to comment.