kwikid-camera
Version:
KwikID's Camera Component
241 lines • 32.6 kB
JavaScript
import { __awaiter } from "tslib";
import { isEmptyValue, isNotEmptyValue } from "kwikid-toolkit";
// TOOLKIT
export function flipImageHorizontally(base64Image) {
// Create an HTML image element
const img = new Image();
img.src = base64Image;
// Create a canvas element
const canvas = document.createElement("canvas");
const ctx = canvas.getContext("2d");
// Set the canvas dimensions to match the image
canvas.width = img.width;
canvas.height = img.height;
// Draw the image on the canvas, flipped horizontally
ctx.scale(-1, 1); // Flip horizontally
ctx.drawImage(img, -canvas.width, 0, canvas.width, canvas.height);
// Convert the canvas content to a base64 string
const flippedBase64 = canvas.toDataURL();
return flippedBase64;
}
// TOOLKIT
export function getDevicesList() {
return __awaiter(this, void 0, void 0, function* () {
const videoDevices = [];
yield navigator.mediaDevices.enumerateDevices().then((devices) => {
for (const device of devices) {
if (device.kind === "videoinput") {
videoDevices.push(device);
}
}
});
return videoDevices;
});
}
// TOOLKIT
export function getDeviceId(activeDeviceId) {
return __awaiter(this, void 0, void 0, function* () {
let deviceId = activeDeviceId;
const videoDevices = [];
yield navigator.mediaDevices.enumerateDevices().then((devices) => {
for (const device of devices) {
if (device.kind === "videoinput") {
videoDevices.push(device);
}
}
});
if (videoDevices.length === 1 || isEmptyValue(activeDeviceId)) {
deviceId = videoDevices[0].deviceId;
}
else {
const filteredVideoDevice = videoDevices.filter((videoDevice) => {
return videoDevice.deviceId !== activeDeviceId;
})[0];
deviceId = filteredVideoDevice.deviceId;
}
return deviceId;
});
}
// TOOLKIT
export function getImageFromBase64(base64String) {
return new Promise((resolve, reject) => {
const image = new Image();
image.onload = () => {
resolve(image);
};
image.onerror = (error) => {
reject(error);
};
image.src = base64String;
});
}
// TOOLKIT
export function getBase64FromImage(image) {
return new Promise((resolve, reject) => {
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
canvas.width = image.width;
canvas.height = image.height;
context.drawImage(image, 0, 0, image.width, image.height);
try {
const base64String = canvas.toDataURL("image/png");
resolve(base64String);
}
catch (error) {
reject(error);
}
});
}
// TOOLKIT
export function getBase64FromImageFile(imageFile) {
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.onload = () => {
const base64String = reader.result;
resolve(base64String); // Resolve the Promise with the base64 string
};
reader.onerror = (error) => {
reject(error); // Reject the Promise in case of an error
};
reader.readAsDataURL(imageFile);
});
}
// TOOLKIT
export function getScaledImageFromVideo(video, flipped) {
return __awaiter(this, void 0, void 0, function* () {
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
const cameraWidth = video.videoWidth;
const cameraHeight = video.videoHeight;
const visibleWidth = video.clientWidth;
const visibleHeight = video.clientHeight;
const cameraRatio = cameraWidth / cameraHeight;
const visibleRatio = visibleWidth / visibleHeight;
let scaledWidth;
let scaledHeight;
if (cameraRatio >= visibleRatio) {
// Scale to Visible Height
const heightRatio = visibleHeight / cameraHeight;
scaledWidth = cameraWidth * heightRatio;
scaledHeight = cameraHeight * heightRatio;
}
else {
// Scale to Visible Width
const widthRatio = visibleWidth / cameraWidth;
scaledWidth = cameraWidth * widthRatio;
scaledHeight = cameraHeight * widthRatio;
}
canvas.width = scaledWidth;
canvas.height = scaledHeight;
if (flipped) {
context.translate(canvas.width, 0);
context.scale(-1, 1);
}
context.drawImage(video, 0, 0, cameraWidth, cameraHeight, 0, 0, scaledWidth, scaledHeight);
// Get the image data from the canvas as a base64-encoded string
const imageBase64 = canvas.toDataURL("image/png");
const image = (yield getImageFromBase64(imageBase64));
return { image, imageBase64 };
});
}
// TOOLKIT
export function getCroppedImage(image, requiredWidth, requiredHeight) {
return __awaiter(this, void 0, void 0, function* () {
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
const sx = (image.width - requiredWidth) / 2;
const sy = (image.height - requiredHeight) / 2;
const sWidth = requiredWidth;
const sHeight = requiredHeight;
const dx = 0;
const dy = 0;
const dWidth = requiredWidth;
const dHeight = requiredHeight;
canvas.width = dWidth;
canvas.height = dHeight;
context.save();
context.translate(0, 0);
context.scale(1, 1);
context.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);
context.restore();
const croppedImageBase64 = canvas.toDataURL("image/png");
const croppedImage = (yield getImageFromBase64(croppedImageBase64));
return { image: croppedImage, imageBase64: croppedImageBase64 };
});
}
// TOOLKIT
export function getCroppedImageFromMask(image, leftShift, topShift, requiredWidth, requiredHeight) {
return __awaiter(this, void 0, void 0, function* () {
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
const sx = leftShift;
const sy = topShift;
const sWidth = requiredWidth;
const sHeight = requiredHeight;
const dx = 0;
const dy = 0;
const dWidth = requiredWidth;
const dHeight = requiredHeight;
canvas.width = dWidth;
canvas.height = dHeight;
context.save();
context.translate(0, 0);
context.scale(1, 1);
context.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);
context.restore();
const croppedImageBase64 = canvas.toDataURL("image/png");
const croppedImage = (yield getImageFromBase64(croppedImageBase64));
return { image: croppedImage, imageBase64: croppedImageBase64 };
});
}
export function getCorrectImageFormat(image) {
if (isEmptyValue(image)) {
return "";
}
if (Array.isArray(image)) {
return image.find((img) => typeof img === "string" && img.length !== 0);
}
if (typeof image === "string") {
return image;
}
return "";
}
// TOOLKIT
export function getWatermarkedImage(image, data) {
return __awaiter(this, void 0, void 0, function* () {
if (isEmptyValue(image)) {
throw new Error("No image provided for watermarking!");
}
if (isEmptyValue(data)) {
return {
image,
imageBase64: yield getBase64FromImage(image),
errorMessage: "No data provided for watermarking!"
};
}
const canvas = document.createElement("canvas");
const context = canvas.getContext("2d");
canvas.width = image.width;
canvas.height = image.height;
context.drawImage(image, 0, 0);
context.font = "12px Arial";
context.textAlign = "left";
context.textBaseline = "top";
context.fillStyle = "#a2a2a2c7";
const longestKey = Object.keys(data).reduce((a, b) => data[a].toString().length > data[b].toString().length ? a : b);
const rectangleWidth = context.measureText(data[longestKey]).width;
context.fillRect(10, 10, rectangleWidth + 95, 70);
context.fillStyle = "yellow";
let yIndex = 20;
for (const key in data) {
if (isNotEmptyValue(key)) {
context.fillText(`${key.split("_").join(" ").toLocaleUpperCase()}: ${data[key]}`, 20, yIndex);
yIndex += 20;
}
}
const watermarkedImageBase64 = canvas.toDataURL("image/png");
const watermarkedImage = (yield getImageFromBase64(watermarkedImageBase64));
return { image: watermarkedImage, imageBase64: watermarkedImageBase64 };
});
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kwikid-camera-view.helper.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-camera/src/lib/components/kwikid-camera-view/kwikid-camera-view.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { isEmptyValue, isNotEmptyValue } from \"kwikid-toolkit\";\n\n// TOOLKIT\nexport function flipImageHorizontally(base64Image: string): string {\n  // Create an HTML image element\n  const img = new Image();\n  img.src = base64Image;\n\n  // Create a canvas element\n  const canvas = document.createElement(\"canvas\");\n  const ctx = canvas.getContext(\"2d\");\n\n  // Set the canvas dimensions to match the image\n  canvas.width = img.width;\n  canvas.height = img.height;\n\n  // Draw the image on the canvas, flipped horizontally\n  ctx.scale(-1, 1); // Flip horizontally\n  ctx.drawImage(img, -canvas.width, 0, canvas.width, canvas.height);\n\n  // Convert the canvas content to a base64 string\n  const flippedBase64 = canvas.toDataURL();\n\n  return flippedBase64;\n}\n\n// TOOLKIT\nexport async function getDevicesList(): Promise<any> {\n  const videoDevices: any[] = [];\n\n  await navigator.mediaDevices.enumerateDevices().then((devices) => {\n    for (const device of devices) {\n      if (device.kind === \"videoinput\") {\n        videoDevices.push(device);\n      }\n    }\n  });\n\n  return videoDevices;\n}\n\n// TOOLKIT\nexport async function getDeviceId(activeDeviceId: string): Promise<string> {\n  let deviceId: string = activeDeviceId;\n  const videoDevices: any[] = [];\n\n  await navigator.mediaDevices.enumerateDevices().then((devices) => {\n    for (const device of devices) {\n      if (device.kind === \"videoinput\") {\n        videoDevices.push(device);\n      }\n    }\n  });\n\n  if (videoDevices.length === 1 || isEmptyValue(activeDeviceId)) {\n    deviceId = videoDevices[0].deviceId;\n  } else {\n    const filteredVideoDevice = videoDevices.filter((videoDevice) => {\n      return videoDevice.deviceId !== activeDeviceId;\n    })[0];\n\n    deviceId = filteredVideoDevice.deviceId;\n  }\n\n  return deviceId;\n}\n\n// TOOLKIT\nexport function getImageFromBase64(\n  base64String: string\n): Promise<HTMLImageElement> {\n  return new Promise((resolve, reject) => {\n    const image = new Image();\n\n    image.onload = () => {\n      resolve(image);\n    };\n\n    image.onerror = (error) => {\n      reject(error);\n    };\n\n    image.src = base64String;\n  });\n}\n\n// TOOLKIT\nexport function getBase64FromImage(image: HTMLImageElement): Promise<string> {\n  return new Promise((resolve, reject) => {\n    const canvas = document.createElement(\"canvas\");\n    const context = canvas.getContext(\"2d\");\n\n    canvas.width = image.width;\n    canvas.height = image.height;\n\n    context.drawImage(image, 0, 0, image.width, image.height);\n\n    try {\n      const base64String = canvas.toDataURL(\"image/png\");\n      resolve(base64String);\n    } catch (error) {\n      reject(error);\n    }\n  });\n}\n\n// TOOLKIT\nexport function getBase64FromImageFile(imageFile: File): Promise<string> {\n  return new Promise((resolve, reject) => {\n    const reader = new FileReader();\n\n    reader.onload = () => {\n      const base64String = reader.result as string;\n      resolve(base64String); // Resolve the Promise with the base64 string\n    };\n\n    reader.onerror = (error) => {\n      reject(error); // Reject the Promise in case of an error\n    };\n\n    reader.readAsDataURL(imageFile);\n  });\n}\n\n// TOOLKIT\nexport async function getScaledImageFromVideo(\n  video: HTMLVideoElement,\n  flipped: boolean\n): Promise<{ image: HTMLImageElement; imageBase64: string }> {\n  const canvas = document.createElement(\"canvas\");\n  const context = canvas.getContext(\"2d\");\n\n  const cameraWidth = video.videoWidth;\n  const cameraHeight = video.videoHeight;\n  const visibleWidth = video.clientWidth;\n  const visibleHeight = video.clientHeight;\n\n  const cameraRatio = cameraWidth / cameraHeight;\n  const visibleRatio = visibleWidth / visibleHeight;\n\n  let scaledWidth;\n  let scaledHeight;\n\n  if (cameraRatio >= visibleRatio) {\n    // Scale to Visible Height\n    const heightRatio = visibleHeight / cameraHeight;\n\n    scaledWidth = cameraWidth * heightRatio;\n    scaledHeight = cameraHeight * heightRatio;\n  } else {\n    // Scale to Visible Width\n    const widthRatio = visibleWidth / cameraWidth;\n\n    scaledWidth = cameraWidth * widthRatio;\n    scaledHeight = cameraHeight * widthRatio;\n  }\n\n  canvas.width = scaledWidth;\n  canvas.height = scaledHeight;\n\n  if (flipped) {\n    context.translate(canvas.width, 0);\n    context.scale(-1, 1);\n  }\n\n  context.drawImage(\n    video,\n    0,\n    0,\n    cameraWidth,\n    cameraHeight,\n    0,\n    0,\n    scaledWidth,\n    scaledHeight\n  );\n\n  // Get the image data from the canvas as a base64-encoded string\n  const imageBase64 = canvas.toDataURL(\"image/png\");\n\n  const image = (await getImageFromBase64(imageBase64)) as HTMLImageElement;\n\n  return { image, imageBase64 };\n}\n\n// TOOLKIT\nexport async function getCroppedImage(\n  image: HTMLImageElement,\n  requiredWidth: number,\n  requiredHeight: number\n): Promise<{ image: HTMLImageElement; imageBase64: string }> {\n  const canvas = document.createElement(\"canvas\");\n  const context = canvas.getContext(\"2d\");\n\n  const sx = (image.width - requiredWidth) / 2;\n  const sy = (image.height - requiredHeight) / 2;\n  const sWidth = requiredWidth;\n  const sHeight = requiredHeight;\n  const dx = 0;\n  const dy = 0;\n  const dWidth = requiredWidth;\n  const dHeight = requiredHeight;\n\n  canvas.width = dWidth;\n  canvas.height = dHeight;\n\n  context.save();\n\n  context.translate(0, 0);\n  context.scale(1, 1);\n\n  context.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);\n\n  context.restore();\n\n  const croppedImageBase64 = canvas.toDataURL(\"image/png\");\n\n  const croppedImage = (await getImageFromBase64(\n    croppedImageBase64\n  )) as HTMLImageElement;\n\n  return { image: croppedImage, imageBase64: croppedImageBase64 };\n}\n\n// TOOLKIT\nexport async function getCroppedImageFromMask(\n  image: HTMLImageElement,\n  leftShift: number,\n  topShift: number,\n  requiredWidth: number,\n  requiredHeight: number\n): Promise<{ image: HTMLImageElement; imageBase64: string }> {\n  const canvas = document.createElement(\"canvas\");\n  const context = canvas.getContext(\"2d\");\n\n  const sx = leftShift;\n  const sy = topShift;\n  const sWidth = requiredWidth;\n  const sHeight = requiredHeight;\n  const dx = 0;\n  const dy = 0;\n  const dWidth = requiredWidth;\n  const dHeight = requiredHeight;\n\n  canvas.width = dWidth;\n  canvas.height = dHeight;\n\n  context.save();\n\n  context.translate(0, 0);\n  context.scale(1, 1);\n\n  context.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);\n\n  context.restore();\n\n  const croppedImageBase64 = canvas.toDataURL(\"image/png\");\n\n  const croppedImage = (await getImageFromBase64(\n    croppedImageBase64\n  )) as HTMLImageElement;\n\n  return { image: croppedImage, imageBase64: croppedImageBase64 };\n}\n\nexport function getCorrectImageFormat(image: any): string {\n  if (isEmptyValue(image)) {\n    return \"\";\n  }\n\n  if (Array.isArray(image)) {\n    return image.find((img) => typeof img === \"string\" && img.length !== 0);\n  }\n\n  if (typeof image === \"string\") {\n    return image;\n  }\n\n  return \"\";\n}\n\n// TOOLKIT\nexport async function getWatermarkedImage(\n  image: HTMLImageElement,\n  data: any\n): Promise<{\n  image: HTMLImageElement;\n  imageBase64: string;\n  errorMessage?: string;\n}> {\n  if (isEmptyValue(image)) {\n    throw new Error(\"No image provided for watermarking!\");\n  }\n  if (isEmptyValue(data)) {\n    return {\n      image,\n      imageBase64: await getBase64FromImage(image),\n      errorMessage: \"No data provided for watermarking!\"\n    };\n  }\n\n  const canvas = document.createElement(\"canvas\");\n  const context = canvas.getContext(\"2d\");\n\n  canvas.width = image.width;\n  canvas.height = image.height;\n\n  context.drawImage(image, 0, 0);\n\n  context.font = \"12px Arial\";\n  context.textAlign = \"left\";\n  context.textBaseline = \"top\";\n  context.fillStyle = \"#a2a2a2c7\";\n\n  const longestKey = Object.keys(data).reduce((a, b) =>\n    data[a].toString().length > data[b].toString().length ? a : b\n  );\n  const rectangleWidth = context.measureText(data[longestKey]).width;\n\n  context.fillRect(10, 10, rectangleWidth + 95, 70);\n  context.fillStyle = \"yellow\";\n\n  let yIndex = 20;\n  for (const key in data) {\n    if (isNotEmptyValue(key)) {\n      context.fillText(\n        `${key.split(\"_\").join(\" \").toLocaleUpperCase()}: ${data[key]}`,\n        20,\n        yIndex\n      );\n      yIndex += 20;\n    }\n  }\n\n  const watermarkedImageBase64: string = canvas.toDataURL(\"image/png\");\n\n  const watermarkedImage = (await getImageFromBase64(\n    watermarkedImageBase64\n  )) as HTMLImageElement;\n\n  return { image: watermarkedImage, imageBase64: watermarkedImageBase64 };\n}\n"]}