2025-07-05 14:49:26 +08:00
|
|
|
|
function hex2Array(hex) {
|
|
|
|
|
//16进制字符串转字节数组
|
|
|
|
|
var result = [];
|
|
|
|
|
if (hex.length % 2 == 1) hex = '0' + hex
|
|
|
|
|
for (var i = 0; i < hex.length; i += 2) {
|
|
|
|
|
result.push(parseInt(hex.substring(i, i + 2), 16));
|
|
|
|
|
}
|
|
|
|
|
result = Uint8Array.from(result)
|
|
|
|
|
return result.buffer
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function array2Hex(value) {
|
|
|
|
|
//value类型为 ArrayBuffer
|
|
|
|
|
let arr = new Uint8Array(value)
|
|
|
|
|
var hex = Buffer.from(arr).toString('hex').toUpperCase()
|
|
|
|
|
return hex
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function string2Array(str) {
|
|
|
|
|
//value类型为 ArrayBuffer
|
|
|
|
|
let arr = new Uint8Array(str.length)
|
|
|
|
|
for (var i = 0; i < str.length; i++) {
|
|
|
|
|
arr[i] = str.charCodeAt(i)
|
|
|
|
|
}
|
|
|
|
|
return arr.buffer
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function array2String(value) {
|
|
|
|
|
//value类型为 ArrayBuffer
|
|
|
|
|
let arr = new Uint8Array(value)
|
|
|
|
|
var str = String.fromCharCode.apply(null, arr)
|
|
|
|
|
console.error('str=[' + str + ']')
|
|
|
|
|
return str
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function formatDate(fmt, date) {
|
|
|
|
|
let ret;
|
|
|
|
|
const opt = {
|
|
|
|
|
"y+": date.getFullYear().toString(), // 年
|
|
|
|
|
"M+": (date.getMonth() + 1).toString(), // 月
|
|
|
|
|
"d+": date.getDate().toString(), // 日
|
|
|
|
|
"H+": date.getHours().toString(), // 时
|
|
|
|
|
"m+": date.getMinutes().toString(), // 分
|
|
|
|
|
"s+": date.getSeconds().toString(), // 秒
|
|
|
|
|
"S+": date.getMilliseconds().toString() // 毫秒
|
|
|
|
|
// 有其他格式化字符需求可以继续添加,必须转化成字符串
|
|
|
|
|
};
|
|
|
|
|
for (let k in opt) {
|
|
|
|
|
ret = new RegExp("(" + k + ")").exec(fmt);
|
|
|
|
|
if (ret) {
|
|
|
|
|
fmt = fmt.replace(ret[1], (ret[1].length == 1) ? (opt[k]) : (opt[k].padStart(ret[1].length, "0")))
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
return fmt;
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-05 16:14:23 +08:00
|
|
|
|
/**
|
|
|
|
|
* 将图片数据转换为硬件需要的RGB565格式(大端序)
|
|
|
|
|
* @param {Uint8ClampedArray} imageData - canvas getImageData返回的像素数据
|
|
|
|
|
* @param {number} width - 图片宽度,默认160
|
|
|
|
|
* @param {number} height - 图片高度,默认80
|
|
|
|
|
* @returns {ArrayBuffer} 转换后的RGB565数据
|
|
|
|
|
*/
|
|
|
|
|
function imageData2RGB565(imageData, width = 160, height = 80) {
|
|
|
|
|
const totalPixels = width * height;
|
|
|
|
|
const rgb565Array = new Uint8Array(totalPixels * 2); // 每个像素2字节
|
|
|
|
|
let arrayIndex = 0;
|
|
|
|
|
|
|
|
|
|
// 每4个字节为一个像素(RGBA)
|
|
|
|
|
for (let i = 0; i < imageData.length; i += 4) {
|
|
|
|
|
const r = imageData[i]; // 红色分量
|
|
|
|
|
const g = imageData[i + 1]; // 绿色分量
|
|
|
|
|
const b = imageData[i + 2]; // 蓝色分量
|
|
|
|
|
// imageData[i + 3] 是alpha透明度,RGB565不需要
|
|
|
|
|
|
|
|
|
|
// 转换为RGB565格式
|
|
|
|
|
const r5 = (r >> 3) & 0x1F; // 8位红色转5位
|
|
|
|
|
const g6 = (g >> 2) & 0x3F; // 8位绿色转6位
|
|
|
|
|
const b5 = (b >> 3) & 0x1F; // 8位蓝色转5位
|
|
|
|
|
|
|
|
|
|
// 合并为16位RGB565值
|
|
|
|
|
const rgb565 = (r5 << 11) | (g6 << 5) | b5;
|
|
|
|
|
|
|
|
|
|
// 大端序存储(高字节在前)
|
|
|
|
|
rgb565Array[arrayIndex++] = (rgb565 >> 8) & 0xFF; // 高字节
|
|
|
|
|
rgb565Array[arrayIndex++] = rgb565 & 0xFF; // 低字节
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return rgb565Array.buffer;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 将RGB565数据转换为十六进制字符串(用于调试)
|
|
|
|
|
* @param {ArrayBuffer} rgb565Data - RGB565数据
|
|
|
|
|
* @returns {string} 十六进制字符串
|
|
|
|
|
*/
|
|
|
|
|
function rgb565ToHexString(rgb565Data) {
|
|
|
|
|
const uint8Array = new Uint8Array(rgb565Data);
|
|
|
|
|
return Array.from(uint8Array)
|
|
|
|
|
.map(byte => byte.toString(16).padStart(2, '0').toUpperCase())
|
|
|
|
|
.join('');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 将RGB565数据转换为C数组格式字符串(用于调试)
|
|
|
|
|
* @param {ArrayBuffer} rgb565Data - RGB565数据
|
|
|
|
|
* @param {string} arrayName - 数组名称,默认'gImage_logo'
|
|
|
|
|
* @returns {string} C数组格式字符串
|
|
|
|
|
*/
|
|
|
|
|
function rgb565ToCArray(rgb565Data, arrayName = 'gImage_logo') {
|
|
|
|
|
const uint8Array = new Uint8Array(rgb565Data);
|
|
|
|
|
let cCode = `const unsigned char ${arrayName}[${uint8Array.length}] = {\n`;
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < uint8Array.length; i += 16) {
|
|
|
|
|
let line = '';
|
|
|
|
|
for (let j = 0; j < 16 && i + j < uint8Array.length; j++) {
|
|
|
|
|
line += `0X${uint8Array[i + j].toString(16).padStart(2, '0').toUpperCase()}`;
|
|
|
|
|
if (i + j < uint8Array.length - 1) line += ',';
|
|
|
|
|
}
|
|
|
|
|
cCode += line + '\n';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cCode += '};\n';
|
|
|
|
|
return cCode;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 验证RGB565数据格式
|
|
|
|
|
* @param {ArrayBuffer} rgb565Data - RGB565数据
|
|
|
|
|
* @param {number} expectedWidth - 期望宽度
|
|
|
|
|
* @param {number} expectedHeight - 期望高度
|
|
|
|
|
* @returns {object} 验证结果
|
|
|
|
|
*/
|
|
|
|
|
function validateRGB565Data(rgb565Data, expectedWidth = 160, expectedHeight = 80) {
|
|
|
|
|
const uint8Array = new Uint8Array(rgb565Data);
|
|
|
|
|
const expectedSize = expectedWidth * expectedHeight * 2;
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
isValid: uint8Array.length === expectedSize,
|
|
|
|
|
actualSize: uint8Array.length,
|
|
|
|
|
expectedSize: expectedSize,
|
|
|
|
|
width: expectedWidth,
|
|
|
|
|
height: expectedHeight,
|
|
|
|
|
pixelCount: uint8Array.length / 2
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-05 14:49:26 +08:00
|
|
|
|
module.exports = {
|
|
|
|
|
hex2Array: hex2Array,
|
|
|
|
|
array2Hex: array2Hex,
|
|
|
|
|
string2Array: string2Array,
|
|
|
|
|
array2String: array2String,
|
2025-07-05 16:14:23 +08:00
|
|
|
|
formatDate: formatDate,
|
|
|
|
|
imageData2RGB565: imageData2RGB565,
|
|
|
|
|
rgb565ToHexString: rgb565ToHexString,
|
|
|
|
|
rgb565ToCArray: rgb565ToCArray,
|
|
|
|
|
validateRGB565Data: validateRGB565Data
|
2025-07-05 14:49:26 +08:00
|
|
|
|
}
|