facebetter 1.0.3 → 1.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/facebetter.esm.js +1106 -0
- package/dist/facebetter.esm.js.map +1 -0
- package/dist/facebetter.js +1104 -0
- package/dist/facebetter.js.map +1 -0
- package/lib/index.js +213 -0
- package/package.json +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"facebetter.js","sources":["../src/core/errors.js","../src/core/config.js","../src/core/constants.js","../src/core/engine.js","../src/browser/wasm-loader.js","../src/browser/image-utils.js","../src/browser/index.js"],"sourcesContent":["/**\n * Facebetter Error Classes\n * Platform-agnostic error handling\n */\n\n/**\n * Facebetter error class\n */\nexport class FacebetterError extends Error {\n constructor(message, code = -1) {\n super(message);\n this.name = 'FacebetterError';\n this.code = code;\n }\n}\n\n/**\n * Checks if a result code indicates success\n * @param {number} result - Result code from WASM function\n * @throws {FacebetterError} If result indicates failure\n */\nexport function checkResult(result, errorMessage = 'Operation failed') {\n if (result !== 0) {\n throw new FacebetterError(`${errorMessage} (error code: ${result})`, result);\n }\n}\n\n","/**\n * Engine Configuration\n * Platform-agnostic configuration class\n */\n\nimport { FacebetterError } from './errors.js';\n\n/**\n * Engine configuration class\n * Similar to EngineConfig struct in C++/Java/OC\n */\nexport class EngineConfig {\n /**\n * Creates a new EngineConfig instance\n * @param {Object} config - Configuration object\n * @param {string} [config.appId] - Application ID (required if licenseJson is not provided)\n * @param {string} [config.appKey] - Application key (required if licenseJson is not provided)\n * @param {string} [config.licenseJson] - License JSON string (optional, if provided, appId and appKey are not required)\n */\n constructor(config = {}) {\n this.appId = config.appId || null;\n this.appKey = config.appKey || null;\n this.licenseJson = config.licenseJson || null;\n this.resourcePath = '/facebetter/resource.bundle';\n }\n\n /**\n * Validates the configuration\n * @returns {boolean} True if valid\n */\n isValid() {\n // 如果提供了 licenseJson,则使用授权数据验证\n if (this.licenseJson) {\n return typeof this.licenseJson === 'string' && this.licenseJson.trim() !== '';\n }\n // 否则需要 appId 和 appKey\n return this.appId && typeof this.appId === 'string' && this.appId.trim() !== '' &&\n this.appKey && typeof this.appKey === 'string' && this.appKey.trim() !== '';\n }\n\n /**\n * Returns a string representation of the config\n * @returns {string} String representation\n */\n toString() {\n return `EngineConfig{appId='${this.appId ? this.appId.substring(0, Math.min(this.appId.length, 8)) + '...' : 'null'}', appKey='${this.appKey ? '***' : 'null'}', licenseJson=${this.licenseJson ? 'provided' : 'null'}}`;\n }\n}\n\n","/**\n * Facebetter Constants and Enums\n * Platform-agnostic constants\n */\n\n/**\n * Beauty type enumeration\n */\nexport const BeautyType = {\n Basic: 0, // 基础美颜\n Reshape: 1, // 面部重塑\n Makeup: 2, // 美妆效果\n Segmentation: 3 // 人像分割\n};\n\n/**\n * Basic beauty parameter enumeration\n */\nexport const BasicParam = {\n Smoothing: 0, // 磨皮\n Sharpening: 1, // 锐化\n Whitening: 2, // 美白\n Rosiness: 3 // 红润\n};\n\n/**\n * Face reshape parameter enumeration\n */\nexport const ReshapeParam = {\n FaceThin: 0, // 瘦脸\n FaceVShape: 1, // V脸\n FaceNarrow: 2, // 窄脸\n FaceShort: 3, // 短脸\n Cheekbone: 4, // 颧骨\n Jawbone: 5, // 下颌骨\n Chin: 6, // 下巴\n NoseSlim: 7, // 瘦鼻梁\n EyeSize: 8, // 大眼\n EyeDistance: 9 // 眼距\n};\n\n/**\n * Makeup parameter enumeration\n */\nexport const MakeupParam = {\n Lipstick: 0, // 口红\n Blush: 1 // 腮红\n};\n\n/**\n * Background mode enumeration\n */\nexport const BackgroundMode = {\n None: 0, // 无背景处理\n Blur: 1, // 模糊背景\n Image: 2 // 背景图片替换\n};\n\n/**\n * Process mode enumeration\n */\nexport const ProcessMode = {\n Image: 0, // 图片模式\n Video: 1 // 视频模式\n};\n\n","/**\n * Beauty Effect Engine Core\n * Platform-agnostic engine implementation with dependency injection\n */\n\nimport { EngineConfig } from './config.js';\nimport { FacebetterError, checkResult } from './errors.js';\nimport { ProcessMode } from './constants.js';\n\n/**\n * Beauty effect engine class\n * Provides high-level API for face beauty effects processing\n * Uses dependency injection for platform-specific functionality\n */\nexport class BeautyEffectEngine {\n /**\n * Creates a new BeautyEffectEngine instance\n * @param {EngineConfig|Object} config - EngineConfig object or configuration object\n * @param {Object} platformAPI - Platform-specific API (injected)\n * @param {Function} platformAPI.loadWasmModule - WASM module loader\n * @param {Function} platformAPI.getWasmModule - Get WASM module instance\n * @param {Function} platformAPI.getWasmBuffer - Get WASM memory buffer\n * @param {Function} platformAPI.toImageData - Convert to ImageData\n * @param {Function} platformAPI.verifyAppKeyOnline - Verify app key online\n * @param {Function} [platformAPI.ensureGPUPixelCanvas] - Ensure GPU canvas exists (browser only)\n * @param {Function} [platformAPI.cleanupGPUPixelCanvas] - Cleanup GPU canvas (browser only)\n */\n constructor(config, platformAPI) {\n if (!config) {\n throw new FacebetterError('Config is required. Expected EngineConfig or configuration object');\n }\n\n if (!platformAPI) {\n throw new FacebetterError('Platform API is required');\n }\n\n // 如果传入的是 EngineConfig 实例,直接使用;否则创建新的 EngineConfig\n let engineConfig;\n if (config instanceof EngineConfig) {\n engineConfig = config;\n } else if (config && typeof config === 'object') {\n engineConfig = new EngineConfig(config);\n } else {\n throw new FacebetterError('Invalid configuration. Expected EngineConfig or configuration object');\n }\n\n if (!engineConfig.isValid()) {\n throw new FacebetterError('Invalid config: ' + engineConfig.toString());\n }\n\n this.config = engineConfig;\n this.appId = engineConfig.appId;\n this.appKey = engineConfig.appKey;\n this.licenseJson = engineConfig.licenseJson;\n this.resourcePath = '/facebetter/resource.bundle';\n this.enginePtr = null;\n this.initialized = false;\n this.srcBufferPtr = null;\n this.dstBufferPtr = null;\n this.bufferSize = 0;\n \n // Store platform API\n this._platformAPI = platformAPI;\n this._loadWasmModule = platformAPI.loadWasmModule;\n this._getWasmModule = platformAPI.getWasmModule;\n this._getWasmBuffer = platformAPI.getWasmBuffer;\n this._toImageData = platformAPI.toImageData;\n this._verifyAppKeyOnline = platformAPI.verifyAppKeyOnline;\n this._ensureGPUPixelCanvas = platformAPI.ensureGPUPixelCanvas;\n this._cleanupGPUPixelCanvas = platformAPI.cleanupGPUPixelCanvas;\n \n // Browser-specific state\n this._gpupixelCanvas = null;\n this._createdGPUPixelCanvas = false;\n this._offscreenCanvas = null;\n this._offscreenCtx = null;\n \n // Automatically create gpupixel_canvas if it doesn't exist (browser only)\n if (this._ensureGPUPixelCanvas) {\n this._ensureGPUPixelCanvas();\n }\n \n // Start loading WASM module immediately in constructor\n this._wasmLoadPromise = this._loadWasmModule();\n }\n\n /**\n * Initializes the engine\n * @returns {Promise<void>} Promise that resolves when initialization is complete\n */\n async init() {\n if (this.initialized) {\n return;\n }\n\n // Wait for WASM module to be loaded (started in constructor)\n await this._wasmLoadPromise;\n const Module = this._getWasmModule();\n\n let licenseJsonToUse = this.licenseJson;\n\n // 如果用户提供了 appId 和 appKey(但没有提供 licenseJson),则在 JS 层发送 HTTP 请求\n if (this.appId && this.appKey && !this.licenseJson && this._verifyAppKeyOnline) {\n try {\n // 在 JS 层调用 online_auth API 获取服务器响应\n const authResponse = await this._verifyAppKeyOnline(this.appId, this.appKey);\n \n if (!authResponse) {\n throw new FacebetterError('Failed to get server response from online_auth API');\n }\n\n // 将服务器响应转换为 JSON 字符串,作为 licenseJson 传递给 WASM 层\n licenseJsonToUse = JSON.stringify(authResponse);\n console.log('Online auth response received, using as licenseJson');\n } catch (error) {\n throw new FacebetterError(`Failed to verify app key online: ${error.message}`);\n }\n }\n\n // 如果用户直接提供了 licenseJson,则直接使用\n // 如果通过 appId/appKey 获取到了响应,则使用响应作为 licenseJson\n // WASM 层只需要验证 licenseJson,不需要发送 HTTP 请求\n const enginePtr = Module.ccall(\n 'CreateBeautyEffectEngine',\n 'number',\n ['string', 'string'],\n [\n this.resourcePath,\n licenseJsonToUse || '' // 使用 licenseJson 验证\n ]\n );\n\n if (!enginePtr) {\n throw new FacebetterError('Failed to create BeautyEffect engine');\n }\n\n this.enginePtr = enginePtr;\n this.initialized = true;\n }\n\n /**\n * Destroys the engine and releases resources\n */\n destroy() {\n if (!this.initialized || !this.enginePtr) {\n return;\n }\n\n const Module = this._getWasmModule();\n\n if (this.srcBufferPtr) {\n Module._free(this.srcBufferPtr);\n this.srcBufferPtr = null;\n }\n\n if (this.dstBufferPtr) {\n Module._free(this.dstBufferPtr);\n this.dstBufferPtr = null;\n }\n\n Module.ccall('DestroyBeautyEffectEngine', null, ['number'], [this.enginePtr]);\n this.enginePtr = null;\n this.initialized = false;\n this.bufferSize = 0;\n \n // Clean up offscreen canvas\n if (this._offscreenCanvas) {\n this._offscreenCanvas = null;\n this._offscreenCtx = null;\n }\n \n // Clean up gpupixel_canvas if we created it\n if (this._cleanupGPUPixelCanvas) {\n this._cleanupGPUPixelCanvas();\n }\n }\n\n /**\n * Sets log configuration\n * Can be called before init() since SetLogConfig is a global function\n * @param {Object} config - Log configuration\n * @param {boolean} config.consoleEnabled - Enable console logging\n * @param {boolean} config.fileEnabled - Enable file logging\n * @param {number} config.level - Log level\n * @param {string} config.fileName - Log file name\n * @returns {Promise<void>} Promise that resolves when log config is set\n */\n async setLogConfig(config) {\n // Wait for WASM module to be loaded (started in constructor)\n await this._wasmLoadPromise;\n const Module = this._getWasmModule();\n\n const result = Module.ccall(\n 'SetLogConfig',\n 'number',\n ['bool', 'bool', 'number', 'string'],\n [\n config.consoleEnabled || false,\n config.fileEnabled || false,\n config.level || 0,\n config.fileName || ''\n ]\n );\n\n checkResult(result, 'Failed to set log config');\n }\n\n /**\n * Enables or disables a beauty type\n * @param {number} beautyType - Beauty type (use BeautyType enum)\n * @param {boolean} enabled - Enable or disable\n */\n setBeautyTypeEnabled(beautyType, enabled) {\n this._ensureInitialized();\n const Module = this._getWasmModule();\n\n const result = Module.ccall(\n 'SetBeautyTypeEnabled',\n 'number',\n ['number', 'number', 'number'],\n [this.enginePtr, beautyType, enabled ? 1 : 0]\n );\n\n checkResult(result, `Failed to ${enabled ? 'enable' : 'disable'} beauty type`);\n }\n\n /**\n * Checks if a beauty type is enabled\n * @param {number} beautyType - Beauty type (use BeautyType enum)\n * @returns {boolean} True if enabled\n */\n isBeautyTypeEnabled(beautyType) {\n this._ensureInitialized();\n const Module = this._getWasmModule();\n\n const result = Module.ccall(\n 'IsBeautyTypeEnabled',\n 'number',\n ['number', 'number'],\n [this.enginePtr, beautyType]\n );\n\n if (result === -1) {\n throw new FacebetterError('Failed to check beauty type status');\n }\n\n return result === 1;\n }\n\n /**\n * Disables all beauty types\n */\n disableAllBeautyTypes() {\n this._ensureInitialized();\n const Module = this._getWasmModule();\n\n const result = Module.ccall(\n 'DisableAllBeautyTypes',\n 'number',\n ['number'],\n [this.enginePtr]\n );\n\n checkResult(result, 'Failed to disable all beauty types');\n }\n\n /**\n * Sets a basic beauty parameter\n * @param {number} param - Parameter (use BasicParam enum)\n * @param {number} value - Parameter value (0.0 - 1.0)\n */\n setBasicParam(param, value) {\n this._ensureInitialized();\n this._setBeautyParam('SetBeautyParamBasic', param, value);\n }\n\n /**\n * Sets a reshape parameter\n * @param {number} param - Parameter (use ReshapeParam enum)\n * @param {number} value - Parameter value (0.0 - 1.0)\n */\n setReshapeParam(param, value) {\n this._ensureInitialized();\n this._setBeautyParam('SetBeautyParamReshape', param, value);\n }\n\n /**\n * Sets a makeup parameter\n * @param {number} param - Parameter (use MakeupParam enum)\n * @param {number} value - Parameter value (0.0 - 1.0)\n */\n setMakeupParam(param, value) {\n this._ensureInitialized();\n this._setBeautyParam('SetBeautyParamMakeup', param, value);\n }\n\n /**\n * Internal method to set beauty parameters\n * @private\n */\n _setBeautyParam(functionName, param, value) {\n if (value < 0 || value > 1) {\n throw new FacebetterError('Parameter value must be between 0.0 and 1.0');\n }\n\n const Module = this._getWasmModule();\n const result = Module.ccall(\n functionName,\n 'number',\n ['number', 'number', 'number'],\n [this.enginePtr, param, value]\n );\n\n checkResult(result, `Failed to set beauty parameter`);\n }\n\n /**\n * Sets virtual background mode\n * @param {number} mode - Background mode (use BackgroundMode enum)\n */\n setVirtualBackgroundMode(mode) {\n this._ensureInitialized();\n const Module = this._getWasmModule();\n\n const result = Module.ccall(\n 'SetVirtualBackgroundMode',\n 'number',\n ['number', 'number'],\n [this.enginePtr, mode]\n );\n\n checkResult(result, 'Failed to set virtual background mode');\n }\n\n /**\n * Sets virtual background image\n * @param {ImageData|HTMLImageElement|HTMLCanvasElement} image - Background image\n */\n setVirtualBackgroundImage(image) {\n this._ensureInitialized();\n const imageData = this._toImageData(image);\n const Module = this._getWasmModule();\n\n const bufferSize = imageData.width * imageData.height * 4;\n const imageBufferPtr = Module._malloc(bufferSize);\n\n try {\n const buffer = this._getWasmBuffer();\n const view = new Uint8Array(buffer, imageBufferPtr, bufferSize);\n view.set(imageData.data);\n\n const result = Module.ccall(\n 'SetVirtualBackgroundImage',\n 'number',\n ['number', 'number', 'number', 'number', 'number'],\n [\n this.enginePtr,\n imageBufferPtr,\n imageData.width,\n imageData.height,\n imageData.width * 4\n ]\n );\n\n checkResult(result, 'Failed to set virtual background image');\n } finally {\n Module._free(imageBufferPtr);\n }\n }\n\n /**\n * Ensures buffers are allocated for the given dimensions\n * @private\n */\n _ensureBuffers(width, height) {\n const requiredSize = width * height * 4;\n\n if (this.bufferSize < requiredSize) {\n const Module = this._getWasmModule();\n\n if (this.srcBufferPtr) {\n Module._free(this.srcBufferPtr);\n }\n if (this.dstBufferPtr) {\n Module._free(this.dstBufferPtr);\n }\n\n this.srcBufferPtr = Module._malloc(requiredSize);\n this.dstBufferPtr = Module._malloc(requiredSize);\n this.bufferSize = requiredSize;\n\n if (!this.srcBufferPtr || !this.dstBufferPtr) {\n throw new FacebetterError('Failed to allocate memory buffers');\n }\n }\n }\n\n /**\n * Processes an image\n * @param {ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement|Uint8ClampedArray} input - Input image\n * @param {number} width - Image width (required if input is Uint8ClampedArray)\n * @param {number} height - Image height (required if input is Uint8ClampedArray)\n * @param {number} processMode - Process mode (use ProcessMode enum, default: ProcessMode.Image)\n * @returns {ImageData} Processed image data\n */\n processImage(input, width, height, processMode = ProcessMode.Image) {\n this._ensureInitialized();\n const imageData = this._platformAPI.toImageData(input, width, height);\n const Module = this._getWasmModule();\n\n this._ensureBuffers(imageData.width, imageData.height);\n\n const bufferSize = imageData.width * imageData.height * 4;\n\n try {\n const buffer = this._getWasmBuffer();\n \n const srcView = new Uint8Array(buffer, this.srcBufferPtr, bufferSize);\n srcView.set(imageData.data);\n\n const result = Module.ccall(\n 'ProcessImageRGBA',\n 'number',\n ['number', 'number', 'number', 'number', 'number', 'number', 'number'],\n [\n this.enginePtr,\n this.srcBufferPtr,\n imageData.width,\n imageData.height,\n imageData.width * 4,\n this.dstBufferPtr,\n processMode\n ]\n );\n\n checkResult(result, 'Failed to process image');\n\n const currentBuffer = this._getWasmBuffer();\n const dstView = new Uint8Array(currentBuffer, this.dstBufferPtr, bufferSize);\n const processedData = new Uint8ClampedArray(dstView);\n\n return new ImageData(processedData, imageData.width, imageData.height);\n } catch (error) {\n if (error instanceof FacebetterError) {\n throw error;\n }\n throw new FacebetterError(`Image processing error: ${error.message}`);\n }\n }\n\n /**\n * Ensures the engine is initialized\n * @private\n * @throws {FacebetterError} If engine is not initialized\n */\n _ensureInitialized() {\n if (!this.initialized || !this.enginePtr) {\n throw new FacebetterError('Engine not initialized. Call init() first.');\n }\n }\n\n /**\n * Ensures gpupixel_canvas exists in the DOM (browser only)\n * This canvas is required by GPUPixel for WebGL context creation\n * @private\n */\n _ensureGPUPixelCanvas() {\n if (typeof document === 'undefined') {\n return;\n }\n \n let canvas = document.getElementById('gpupixel_canvas');\n if (!canvas) {\n canvas = document.createElement('canvas');\n canvas.id = 'gpupixel_canvas';\n canvas.style.display = 'none';\n canvas.width = 1;\n canvas.height = 1;\n document.body.appendChild(canvas);\n this._createdGPUPixelCanvas = true;\n }\n this._gpupixelCanvas = canvas;\n }\n\n /**\n * Cleans up gpupixel_canvas if it was created by this engine instance (browser only)\n * @private\n */\n _cleanupGPUPixelCanvas() {\n if (this._createdGPUPixelCanvas && this._gpupixelCanvas) {\n this._gpupixelCanvas.remove();\n this._gpupixelCanvas = null;\n this._createdGPUPixelCanvas = false;\n }\n }\n\n /**\n * Ensures offscreen canvas exists and matches the required dimensions (browser only)\n * This canvas is reused for video processing to avoid creating temporary canvases\n * @private\n * @param {number} width - Required canvas width\n * @param {number} height - Required canvas height\n */\n _ensureOffscreenCanvas(width, height) {\n if (typeof document === 'undefined') {\n return null;\n }\n \n if (!this._offscreenCanvas || \n this._offscreenCanvas.width !== width || \n this._offscreenCanvas.height !== height) {\n this._offscreenCanvas = document.createElement('canvas');\n this._offscreenCanvas.width = width;\n this._offscreenCanvas.height = height;\n this._offscreenCtx = this._offscreenCanvas.getContext('2d', { willReadFrequently: true });\n }\n return this._offscreenCanvas;\n }\n\n}\n\n","/**\n * Browser-specific WASM Module Loader\n * Uses document.currentScript for automatic path detection\n */\n\n/**\n * Gets the base path of the current script\n * Similar to Node.js __dirname\n * Handles various deployment scenarios: same directory, CDN, subdirectories\n * @returns {string} Base path of the current script (with trailing slash)\n */\nexport function getScriptBasePath() {\n let scriptUrl = null;\n \n // Method 1: document.currentScript (most reliable, works in sync execution)\n if (typeof document !== 'undefined' && document.currentScript?.src) {\n scriptUrl = document.currentScript.src;\n }\n \n // Method 2: Traverse script tags (fallback for async scripts)\n if (!scriptUrl && typeof document !== 'undefined') {\n const scripts = document.getElementsByTagName('script');\n // Check from end to start (most recent first)\n for (let i = scripts.length - 1; i >= 0; i--) {\n const src = scripts[i].src;\n if (src && (src.includes('facebetter.js') || src.includes('facebetter'))) {\n scriptUrl = src;\n break;\n }\n }\n }\n \n // Method 3: Try to find script by checking all scripts\n if (!scriptUrl && typeof document !== 'undefined') {\n const scripts = document.getElementsByTagName('script');\n for (let i = scripts.length - 1; i >= 0; i--) {\n const src = scripts[i].src;\n if (src) {\n // Use the last script tag as fallback\n scriptUrl = src;\n break;\n }\n }\n }\n \n // Extract base path from script URL\n if (scriptUrl) {\n try {\n const url = new URL(scriptUrl);\n return url.href.substring(0, url.href.lastIndexOf('/') + 1);\n } catch (e) {\n // If URL parsing fails, use string manipulation\n return scriptUrl.substring(0, scriptUrl.lastIndexOf('/') + 1);\n }\n }\n \n // Method 4: Fallback to current location (least reliable)\n if (typeof location !== 'undefined') {\n try {\n const url = new URL('.', location.href);\n return url.href;\n } catch (e) {\n return location.pathname.substring(0, location.pathname.lastIndexOf('/') + 1);\n }\n }\n \n // Last resort\n return './';\n}\n\n/**\n * Resolves a relative path to absolute URL\n * Handles various path formats and edge cases\n * @param {string} relativePath - Relative path (e.g., 'facebetter_wasm.js')\n * @param {string} basePath - Base path (with trailing slash)\n * @returns {string} Absolute URL\n */\nexport function resolvePath(relativePath, basePath) {\n // If relativePath is already absolute, return as-is\n if (relativePath.startsWith('http://') || relativePath.startsWith('https://') || relativePath.startsWith('//')) {\n return relativePath;\n }\n \n try {\n // Use URL API for proper resolution\n const base = basePath.endsWith('/') ? basePath : basePath + '/';\n return new URL(relativePath, base).href;\n } catch (e) {\n // Fallback: simple concatenation\n const base = basePath.endsWith('/') ? basePath : basePath + '/';\n // Remove leading ./ from relativePath if present\n const cleanPath = relativePath.replace(/^\\.\\//, '');\n return base + cleanPath;\n }\n}\n\nlet wasmModulePromise = null;\nlet wasmModuleInstance = null;\n\n/**\n * Loads the WebAssembly module (browser version)\n * @param {string} [wasmPath] - Path to facebetter_wasm.js (auto-detected if not provided)\n * @param {Object} [options] - Options\n * @param {Function} [options.locateFile] - Custom locateFile function\n * @returns {Promise<Object>} Promise that resolves with the WASM module\n */\nexport function loadWasmModule(wasmPath, options = {}) {\n if (wasmModuleInstance) {\n return Promise.resolve(wasmModuleInstance);\n }\n\n if (wasmModulePromise) {\n return wasmModulePromise;\n }\n\n wasmModulePromise = new Promise((resolve, reject) => {\n // Check if Module is already available\n if (typeof Module !== 'undefined' && Module.ready) {\n wasmModuleInstance = Module;\n resolve(Module);\n return;\n }\n\n // Initialize Module if not exists\n if (typeof Module === 'undefined') {\n if (typeof window !== 'undefined') {\n window.Module = {};\n } else if (typeof global !== 'undefined') {\n global.Module = {};\n } else {\n reject(new Error('Cannot find global object (window/global)'));\n return;\n }\n }\n\n // Auto-detect wasm path if not provided\n if (!wasmPath) {\n const basePath = getScriptBasePath();\n wasmPath = resolvePath('facebetter_wasm.js', basePath);\n }\n\n // Configure Module.locateFile for automatic resource resolution\n const basePath = getScriptBasePath();\n const originalLocateFile = Module.locateFile || function(path, prefix) {\n return prefix + path;\n };\n\n Module.locateFile = function(path, prefix) {\n // Use custom locateFile if provided\n if (options.locateFile) {\n return options.locateFile(path, prefix);\n }\n \n // Auto-resolve .wasm and .data files\n if (path.endsWith('.wasm') || path.endsWith('.data')) {\n return resolvePath(path, basePath);\n }\n \n return originalLocateFile(path, prefix);\n };\n\n // Load WASM script\n const script = document.createElement('script');\n script.src = wasmPath;\n script.onload = () => {\n if (typeof Module.onRuntimeInitialized === 'undefined') {\n Module.onRuntimeInitialized = () => {\n Module.ready = true;\n wasmModuleInstance = Module;\n resolve(Module);\n };\n } else {\n const originalInit = Module.onRuntimeInitialized;\n Module.onRuntimeInitialized = () => {\n if (originalInit) originalInit();\n Module.ready = true;\n wasmModuleInstance = Module;\n resolve(Module);\n };\n }\n };\n script.onerror = () => {\n wasmModulePromise = null;\n reject(new Error(`Failed to load WASM module from ${wasmPath}`));\n };\n document.head.appendChild(script);\n });\n\n return wasmModulePromise;\n}\n\n/**\n * Gets the current WASM module instance\n * @returns {Object} WASM module instance\n * @throws {Error} If module is not loaded\n */\nexport function getWasmModule() {\n if (!wasmModuleInstance) {\n throw new Error('WASM module not loaded. Call loadWasmModule() first or use BeautyEffectEngine.init()');\n }\n return wasmModuleInstance;\n}\n\n/**\n * Gets the current WASM memory buffer, handling potential reallocation\n * @returns {ArrayBuffer} Current WASM memory buffer\n */\nexport function getWasmBuffer() {\n const Module = getWasmModule();\n \n if (Module.buffer) {\n return Module.buffer;\n } else if (Module.HEAPU8 && Module.HEAPU8.buffer) {\n return Module.HEAPU8.buffer;\n } else if (Module.asm && Module.asm.memory) {\n return Module.asm.memory.buffer;\n }\n \n throw new Error('Unable to access WASM memory buffer');\n}\n\n","/**\n * Browser-specific Image Utilities\n * Uses DOM APIs (canvas, ImageData, etc.)\n */\n\nimport { FacebetterError } from '../core/errors.js';\n\n/**\n * Converts various image sources to ImageData (browser version)\n * @param {ImageData|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement|Uint8ClampedArray} source - Image source\n * @param {number} width - Image width (required if source is Uint8ClampedArray)\n * @param {number} height - Image height (required if source is Uint8ClampedArray)\n * @returns {ImageData} ImageData object\n */\nexport function toImageData(source, width, height) {\n if (source instanceof ImageData) {\n return source;\n }\n\n if (source instanceof HTMLCanvasElement || source instanceof HTMLVideoElement) {\n const canvas = source instanceof HTMLCanvasElement ? source : document.createElement('canvas');\n if (source instanceof HTMLVideoElement) {\n canvas.width = source.videoWidth;\n canvas.height = source.videoHeight;\n const ctx = canvas.getContext('2d');\n ctx.drawImage(source, 0, 0);\n }\n const ctx = canvas.getContext('2d');\n return ctx.getImageData(0, 0, canvas.width, canvas.height);\n }\n\n if (source instanceof HTMLImageElement) {\n const canvas = document.createElement('canvas');\n canvas.width = source.naturalWidth || source.width;\n canvas.height = source.naturalHeight || source.height;\n const ctx = canvas.getContext('2d');\n ctx.drawImage(source, 0, 0);\n return ctx.getImageData(0, 0, canvas.width, canvas.height);\n }\n\n if (source instanceof Uint8ClampedArray) {\n if (width === undefined || height === undefined) {\n throw new FacebetterError('Width and height are required when source is Uint8ClampedArray');\n }\n return new ImageData(source, width, height);\n }\n\n throw new FacebetterError('Unsupported image source type');\n}\n\n/**\n * Gets User-Agent string for web platform\n * @returns {string} User-Agent string\n */\nexport function getUserAgentString() {\n return 'FB/1.0 (web; wasm32)';\n}\n\n/**\n * Generates HMAC-SHA256 signature (browser version)\n * @param {string} key - HMAC key (app_key)\n * @param {string} data - Data to sign (timestamp string)\n * @returns {Promise<string>} Promise that resolves with hex-encoded signature\n */\nexport async function generateHMACSignature(key, data) {\n const encoder = new TextEncoder();\n const keyData = encoder.encode(key);\n const messageData = encoder.encode(data);\n\n const cryptoKey = await crypto.subtle.importKey(\n 'raw',\n keyData,\n { name: 'HMAC', hash: 'SHA-256' },\n false,\n ['sign']\n );\n\n const signature = await crypto.subtle.sign('HMAC', cryptoKey, messageData);\n\n // Convert to hex string\n const hashArray = Array.from(new Uint8Array(signature));\n const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('');\n return hashHex;\n}\n\n/**\n * Calls online_auth API to verify app_key (browser version)\n * @param {string} appId - Application ID\n * @param {string} appKey - Application key\n * @returns {Promise<Object>} Promise that resolves with response data\n */\nexport async function verifyAppKeyOnline(appId, appKey) {\n try {\n const timestamp = Math.floor(Date.now() / 1000);\n const timestampStr = timestamp.toString();\n const hmacSignature = await generateHMACSignature(appKey, timestampStr);\n\n const requestBody = {\n p_app_id: appId,\n p_hmac_signature: hmacSignature,\n p_timestamp: timestamp,\n p_user_agent: getUserAgentString()\n };\n\n const response = await fetch('https://facebetter.pixpark.net/rest/v1/rpc/online_auth', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'User-Agent': getUserAgentString()\n },\n body: JSON.stringify(requestBody)\n });\n\n const responseData = await response.json();\n return responseData;\n } catch (error) {\n console.error('Online auth request failed:', error);\n return null;\n }\n}\n\n","/**\n * Browser Entry Point\n * For <script> tag usage (UMD format)\n */\n\nimport { BeautyEffectEngine } from '../core/engine.js';\nimport { EngineConfig } from '../core/config.js';\nimport { FacebetterError } from '../core/errors.js';\nimport * as constants from '../core/constants.js';\nimport * as wasmLoader from './wasm-loader.js';\nimport * as imageUtils from './image-utils.js';\n\n// Browser-specific GPU canvas management\nfunction ensureGPUPixelCanvas() {\n if (typeof document === 'undefined') {\n return;\n }\n \n let canvas = document.getElementById('gpupixel_canvas');\n if (!canvas) {\n canvas = document.createElement('canvas');\n canvas.id = 'gpupixel_canvas';\n canvas.style.display = 'none';\n canvas.width = 1;\n canvas.height = 1;\n if (document.body) {\n document.body.appendChild(canvas);\n }\n }\n}\n\nfunction cleanupGPUPixelCanvas() {\n // Cleanup is handled by engine instance\n}\n\n// Create platform API\nconst platformAPI = {\n loadWasmModule: () => wasmLoader.loadWasmModule(),\n getWasmModule: wasmLoader.getWasmModule,\n getWasmBuffer: wasmLoader.getWasmBuffer,\n toImageData: imageUtils.toImageData,\n verifyAppKeyOnline: imageUtils.verifyAppKeyOnline,\n ensureGPUPixelCanvas,\n cleanupGPUPixelCanvas\n};\n\n// Export factory function for UMD\nexport function createBeautyEffectEngine(config) {\n return new BeautyEffectEngine(config, platformAPI);\n}\n\n// Create a wrapped BeautyEffectEngine class that automatically injects platformAPI\n// This allows users to use: new BeautyEffectEngine(config) without passing platformAPI\nclass BrowserBeautyEffectEngine extends BeautyEffectEngine {\n constructor(config) {\n // Automatically inject platformAPI for browser environment\n super(config, platformAPI);\n }\n}\n\n// Export all constants and classes\nexport {\n BrowserBeautyEffectEngine as BeautyEffectEngine,\n EngineConfig,\n FacebetterError\n};\n\n// Export constants with proper names\nexport const BeautyType = constants.BeautyType;\nexport const BasicParam = constants.BasicParam;\nexport const ReshapeParam = constants.ReshapeParam;\nexport const MakeupParam = constants.MakeupParam;\nexport const BackgroundMode = constants.BackgroundMode;\nexport const ProcessMode = constants.ProcessMode;\n\n// Export WASM loader\nexport { loadWasmModule } from './wasm-loader.js';\n\n// Default export\nexport default {\n BeautyEffectEngine: BrowserBeautyEffectEngine,\n EngineConfig,\n FacebetterError,\n ...constants,\n loadWasmModule: wasmLoader.loadWasmModule\n};\n\n"],"names":["BeautyType","BasicParam","ReshapeParam","MakeupParam","BackgroundMode","ProcessMode","wasmLoader.loadWasmModule","wasmLoader.getWasmModule","wasmLoader.getWasmBuffer","imageUtils.toImageData","imageUtils.verifyAppKeyOnline","constants.BeautyType","constants.BasicParam","constants.ReshapeParam","constants.MakeupParam","constants.BackgroundMode","constants.ProcessMode"],"mappings":"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"}
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Node.js Entry Point
|
|
3
|
+
* For Node.js and Electron main process
|
|
4
|
+
* Uses fs.readFileSync for synchronous WASM loading
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { readFileSync } from 'fs';
|
|
8
|
+
import { join, dirname, resolve } from 'path';
|
|
9
|
+
import { fileURLToPath } from 'url';
|
|
10
|
+
import { BeautyEffectEngine } from '../core/engine.js';
|
|
11
|
+
import { EngineConfig } from '../core/config.js';
|
|
12
|
+
import { FacebetterError } from '../core/errors.js';
|
|
13
|
+
import * as constants from '../core/constants.js';
|
|
14
|
+
|
|
15
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
16
|
+
const __dirname = dirname(__filename);
|
|
17
|
+
|
|
18
|
+
// WASM files directory - in package dist/ folder
|
|
19
|
+
// src/engine/web/src/node -> src/engine/web/src -> src/engine/web -> dist
|
|
20
|
+
const wasmBinDir = resolve(__dirname, '../../dist');
|
|
21
|
+
|
|
22
|
+
// Node.js-specific WASM loader
|
|
23
|
+
let wasmModuleInstance = null;
|
|
24
|
+
let wasmModulePromise = null;
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Gets the base path of the current module
|
|
28
|
+
* Node.js equivalent of __dirname
|
|
29
|
+
* @returns {string} Base path of the current module
|
|
30
|
+
*/
|
|
31
|
+
function getModuleBasePath() {
|
|
32
|
+
return __dirname;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Resolves a relative path to absolute path (Node.js version)
|
|
37
|
+
* @param {string} relativePath - Relative path
|
|
38
|
+
* @returns {string} Absolute path
|
|
39
|
+
*/
|
|
40
|
+
function resolvePath(relativePath) {
|
|
41
|
+
return join(__dirname, relativePath);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Loads the WebAssembly module (Node.js version)
|
|
46
|
+
* Uses fs.readFileSync for synchronous loading
|
|
47
|
+
* @param {Object} [options] - Options
|
|
48
|
+
* @param {string} [options.wasmPath] - Custom WASM path (auto-detected if not provided)
|
|
49
|
+
* @returns {Promise<Object>} Promise that resolves with the WASM module
|
|
50
|
+
*/
|
|
51
|
+
export async function loadWasmModule(options = {}) {
|
|
52
|
+
if (wasmModuleInstance) {
|
|
53
|
+
return wasmModuleInstance;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (wasmModulePromise) {
|
|
57
|
+
return wasmModulePromise;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
wasmModulePromise = (async () => {
|
|
61
|
+
try {
|
|
62
|
+
// Resolve WASM file paths (use project root directory)
|
|
63
|
+
const wasmPath = options.wasmPath || join(wasmBinDir, 'facebetter.wasm');
|
|
64
|
+
const wasmJsPath = join(wasmBinDir, 'facebetter_wasm.js');
|
|
65
|
+
|
|
66
|
+
// Read WASM binary synchronously
|
|
67
|
+
const wasmBinary = readFileSync(wasmPath);
|
|
68
|
+
|
|
69
|
+
// Import the WASM module factory
|
|
70
|
+
const module = await import(wasmJsPath);
|
|
71
|
+
const FaceBetterModuleFactory = module.default || module;
|
|
72
|
+
|
|
73
|
+
// Initialize the module with binary data
|
|
74
|
+
wasmModuleInstance = await FaceBetterModuleFactory({
|
|
75
|
+
wasmBinary, // Direct binary, no network request
|
|
76
|
+
locateFile: (path) => {
|
|
77
|
+
if (path.endsWith('.wasm')) {
|
|
78
|
+
return wasmPath;
|
|
79
|
+
}
|
|
80
|
+
if (path.endsWith('.data')) {
|
|
81
|
+
return join(wasmBinDir, 'facebetter_wasm.data');
|
|
82
|
+
}
|
|
83
|
+
return path;
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
if (!wasmModuleInstance) {
|
|
88
|
+
throw new FacebetterError('Failed to initialize WASM module');
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
wasmModuleInstance.ready = true;
|
|
92
|
+
return wasmModuleInstance;
|
|
93
|
+
} catch (e) {
|
|
94
|
+
throw new FacebetterError(`Failed to load WASM module: ${e.message}`);
|
|
95
|
+
}
|
|
96
|
+
})();
|
|
97
|
+
|
|
98
|
+
return wasmModulePromise;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Gets the current WASM module instance
|
|
103
|
+
* @returns {Object} WASM module instance
|
|
104
|
+
* @throws {Error} If module is not loaded
|
|
105
|
+
*/
|
|
106
|
+
export function getWasmModule() {
|
|
107
|
+
if (!wasmModuleInstance) {
|
|
108
|
+
throw new Error('WASM module not loaded. Call loadWasmModule() first or use BeautyEffectEngine.init()');
|
|
109
|
+
}
|
|
110
|
+
return wasmModuleInstance;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Gets the current WASM memory buffer
|
|
115
|
+
* @returns {ArrayBuffer} Current WASM memory buffer
|
|
116
|
+
*/
|
|
117
|
+
export function getWasmBuffer() {
|
|
118
|
+
const Module = getWasmModule();
|
|
119
|
+
|
|
120
|
+
if (Module.buffer) {
|
|
121
|
+
return Module.buffer;
|
|
122
|
+
} else if (Module.HEAPU8 && Module.HEAPU8.buffer) {
|
|
123
|
+
return Module.HEAPU8.buffer;
|
|
124
|
+
} else if (Module.asm && Module.asm.memory) {
|
|
125
|
+
return Module.asm.memory.buffer;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
throw new Error('Unable to access WASM memory buffer');
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// Node.js doesn't have ImageData, so we need a different approach
|
|
132
|
+
// For Node.js, users should work with raw buffers
|
|
133
|
+
function toImageData(source, width, height) {
|
|
134
|
+
// In Node.js, we expect Uint8ClampedArray or Buffer
|
|
135
|
+
if (source instanceof Uint8ClampedArray) {
|
|
136
|
+
if (width === undefined || height === undefined) {
|
|
137
|
+
throw new FacebetterError('Width and height are required for Node.js');
|
|
138
|
+
}
|
|
139
|
+
// Create a simple object that mimics ImageData
|
|
140
|
+
return {
|
|
141
|
+
data: source,
|
|
142
|
+
width,
|
|
143
|
+
height
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
if (Buffer.isBuffer(source)) {
|
|
148
|
+
if (width === undefined || height === undefined) {
|
|
149
|
+
throw new FacebetterError('Width and height are required for Node.js');
|
|
150
|
+
}
|
|
151
|
+
return {
|
|
152
|
+
data: new Uint8ClampedArray(source),
|
|
153
|
+
width,
|
|
154
|
+
height
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
throw new FacebetterError('Unsupported image source type for Node.js. Use Uint8ClampedArray or Buffer.');
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
// Node.js doesn't support online auth (no fetch in older versions)
|
|
162
|
+
// Users should provide licenseJson directly
|
|
163
|
+
async function verifyAppKeyOnline(appId, appKey) {
|
|
164
|
+
throw new FacebetterError('Online authentication is not supported in Node.js. Please provide licenseJson directly.');
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
// No GPU canvas in Node.js
|
|
168
|
+
function ensureGPUPixelCanvas() {
|
|
169
|
+
// No-op for Node.js
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
function cleanupGPUPixelCanvas() {
|
|
173
|
+
// No-op for Node.js
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
// Create platform API
|
|
177
|
+
const platformAPI = {
|
|
178
|
+
loadWasmModule: () => loadWasmModule(),
|
|
179
|
+
getWasmModule,
|
|
180
|
+
getWasmBuffer,
|
|
181
|
+
toImageData,
|
|
182
|
+
verifyAppKeyOnline,
|
|
183
|
+
ensureGPUPixelCanvas,
|
|
184
|
+
cleanupGPUPixelCanvas
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
// Export factory function
|
|
188
|
+
export function createBeautyEffectEngine(config) {
|
|
189
|
+
return new BeautyEffectEngine(config, platformAPI);
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
// Export all constants and classes
|
|
193
|
+
export {
|
|
194
|
+
BeautyEffectEngine,
|
|
195
|
+
EngineConfig,
|
|
196
|
+
FacebetterError,
|
|
197
|
+
BeautyType: constants.BeautyType,
|
|
198
|
+
BasicParam: constants.BasicParam,
|
|
199
|
+
ReshapeParam: constants.ReshapeParam,
|
|
200
|
+
MakeupParam: constants.MakeupParam,
|
|
201
|
+
BackgroundMode: constants.BackgroundMode,
|
|
202
|
+
ProcessMode: constants.ProcessMode
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
// Default export
|
|
206
|
+
export default {
|
|
207
|
+
BeautyEffectEngine: (config) => new BeautyEffectEngine(config, platformAPI),
|
|
208
|
+
EngineConfig,
|
|
209
|
+
FacebetterError,
|
|
210
|
+
...constants,
|
|
211
|
+
loadWasmModule
|
|
212
|
+
};
|
|
213
|
+
|