Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

.toDataURL produces different base64 text on different platforms #967

Open
soadzoor opened this issue Dec 26, 2024 · 2 comments
Open

.toDataURL produces different base64 text on different platforms #967

soadzoor opened this issue Dec 26, 2024 · 2 comments

Comments

@soadzoor
Copy link

soadzoor commented Dec 26, 2024

Hey,

I have a unit-test for thumbnail generation. Roughly, it works like this:

const vertices: PointDouble[] = [
	{x: 21, y: 11},
	{x: 21, y: 2},
	{x: 2, y: 7},
];
const boundarySpaceMap = new BoundarySpaceMap(
	{geometry: {polygonShape: {vertices}}}
);

expect(boundarySpaceMap.thumbnail).toEqual(
""
);

The base64 string above is hardcoded from the first test which was generated on an ubuntu machine. It works on the ubuntu machine fine.

However, when I run the same test on my mac (m1 pro), it fails, because the received base64 string is different:



For easier comparison, here they are again:
Thumbnail base64 generated on ubuntu (2170 characters long):



Thumbnail generated on mac (m1 pro) (2182 characters long):



Seemingly, they have the same exact colors, and same content, when I parse them as images. But somehow the base64 encoding is different. Maybe they use different levels of compression..?

Here is the logic for generating the thumbnail (I know it has some external functions, it you need those implementations as well, let me know):

public get thumbnail() {
		const canvas = ImageUtils.canvas;
		const ctx = ImageUtils.ctx;

		const dimension = Constants.RESOLUTION.XYICON;

		canvas.width = canvas.height = dimension;

		ctx.clearRect(0, 0, canvas.width, canvas.height);

		const geometryData = this.geometryData;
		const canvasCoords = THREEUtils.spaceCoordsToThumbnailCoords(geometryData, dimension, 1 / dimension);

		ctx.beginPath();

		ctx.moveTo(canvasCoords[0].x, canvasCoords[0].y);

		for (let i = 1; i < canvasCoords.length; ++i) {
			ctx.lineTo(canvasCoords[i].x, canvasCoords[i].y);
		}

		ctx.closePath();

		const color = this._parent.color.hex;

		ctx.strokeStyle = `#${color}`;
		const {r, g, b, a} = ColorUtils.hex2rgb(color, 0.1, "RGBObject") as IRGBObject;

		ctx.fillStyle = `rgba(${r}, ${g}, ${b}, ${a})`;

		ctx.stroke();
		ctx.fill();

		return canvas.toDataURL();
}
@soadzoor
Copy link
Author

soadzoor commented Dec 26, 2024

Some additional tests show me that the ctx.getImageData also produces slightly different numbers on mac vs ubuntu.
Maybe the default colorspace is different? How could I make them the same?

@soadzoor
Copy link
Author

soadzoor commented Dec 26, 2024

Comparing the two images here: https://www.diffchecker.com/image-compare/
When using the slider option, it's quite obvious that the lines are a bit different (in their thickness, maybe):
Screenshot 2024-12-26 at 20 59 41

Is there something you could do about this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant