您现在的位置是:网站首页> HTML&JS
OpenCV.js 快速入门指南
- HTML&JS
- 2023-05-23
- 1110人已阅读
OpenCV.js 快速入门指南
windows下安装emsdk
先从github上下载emsdk工程:
# Get the emsdk repo
git clone https://github.com/emscripten-core/emsdk.git
# Enter that directory
cd emsdk
git pull 更新到最新代码
clone 工程可以在 git bash here 命令行下:
执行下面的指令用cmd命令行:
更新完成后安装最新的emsdk,并配置全局的环境变量:
emsdk install --global latest
当安装完成配置好后执行激活:
emsdk activate latest
这里的emsdk 命令 其实就是一个emsdk.bat的批处理文件
emsdk.bat install --global latest
激活:
配置环境变量:
测试是否安装成功:
成功后在浏览器中输入http://localhost:8080/hello.html就会在控制台看到输出的“Hello, world!”。
构建过程
安装Emscripten SDK
git clone https://github.com/juj/emsdk.git
cd emsdk
./emsdk install latest
./emsdk activate latest
source ./emsdk_env.sh
获取OpenCV
wget https://github.com/opencv/opencv/archive/3.4.1.zip
unzip 3.4.1.zip
cd opencv-3.4.1
# 将OpenCV编译为WASM版本
python ./platform/js/build_js.py build_wasm --build_wasm
1. 简介
OpenCV.js: OpenCV 的 JavaScript 版本
官方指南:OpenCV.js Tutorials
2. 下载
可通过如下链接下载到指定版本的预编译 opencv.js 文件
https://docs.opencv.org/{version}/opencv.js
比如下载 4.5.5 版本的 opencv.js 文件
https://docs.opencv.org/4.5.5/opencv.js
3. 安装使用
HTML script 标签引入
<!-- OpenCV.js 4.5.5 版本 -->
<script src='https://docs.opencv.org/4.5.5/opencv.js'></script>
node.js 使用
// 加载 OpenCV.js
function loadOpenCV(path) {
return new Promise(resolve => {
global.Module = {
onRuntimeInitialized: resolve
};
global.cv = require(path);
});
}
// 加载并创建一个图像
async function run(path){
await loadOpenCV(path)
let img = new cv.Mat()
img.delete()
}
// 设置文件路径
const path = './opencv.js'
// 运行
run(path)
4. 数据类型
图像数据类型
Mat 是 OpenCV 基础的图像数据结构,其数据类型对照表如下:
Data Properties C++ Type JavaScript Typed Array Mat Type
data uchar Uint8Array CV_8U
data8S char Int8Array CV_8S
data16U ushort Uint16Array CV_16U
data16S short Int16Array CV_16S
data32S int Int32Array CV_32S
data32F float Float32Array CV_32F
data64F double Float64Array CV_64F
MatVector 即多个 Mat 组成的向量,使用 push_back(mat: cv.Mat)、 get(index: number) 和 set(index: number, mat: cv.Mat)方法添加、读取和设置 Mat 至 MatVector 中
Mat 和 MatVector 类型的变量请在不再需要使用的时候使用 delete() 方法将其删除,否则该变量将会持续占用内存
简单的创建和删除方式如下:
// 创建一个 Mat
let mat = new cv.Mat()
// 创建一个 MatVector
let matVector = new cv.MatVector()
// 添加一个 Mat
matVector.push_back(mat)
// 获取 index 为 0 的 Mat
mat = matVector.get(0)
// 设置 index 为 0 的 Mat
matVector.set(0, mat)
// 删除 Mat
mat.delete()
// 删除 MatVector
matVector.delete()
其他数据类型及其对应的 JS 对象格式,创建变量时两种方式均可使用
// 坐标点
new cv.Point(x, y) = {
x: number,
y: number
}
// 像素点
new cv.Scalar(R, G, B, Alpha) = [
R: number,
G: number,
B: number,
Alpha: number
]
// 图像尺寸
new cv.Size(width, height) = {
width: number,
height: number
}
// 圆形区域
new cv.Circle(center, radius) = {
center: {
x: number,
y: number
},
radius: number
}
// 矩形区域
new cv.Rect(x, y, width, height) = {
x: number,
y: number,
width: number,
height: number
}
// 旋转矩形区域
new cv.RotatedRect(center, size, angle) = {
center: {
x: number,
y: number
},
size: {
width: number,
height: number
},
angle: number
}
5. API
OpenCV.js 的 API 与 OpenCV C++ 版本 API 非常相似
OpenCV.js 常用的 API 如下:
图像读取和显示
// 读取
cv.imread(dom) -> dst
// 显示
cv.imshow(dst, dom)
dom(Dom/string): img 标签或其 id(读取) / canvas 标签或其 id(读取/显示)
dst(cv.Mat): 图像(RGBA)
创建图像
// 创建一个 Mat 格式的图像
new cv.Mat() -> mat
new cv.Mat(size, type) -> mat
new cv.Mat(rows, cols, type) -> mat
new cv.Mat(rows, cols, type, scalar) -> mat
// 创建一个值全部为零的图像
cv.Mat.zeros(rows, cols, type) -> mat
// 创建一个值全部为一的图像
cv.Mat.ones(rows, cols, type) -> mat
// 创建一个对角线值为一的图像
cv.Mat.eye(rows, cols, type) -> mat
// 使用 JS Array 生成图像
cv.matFromArray(rows, cols, type, array) -> mat
// 使用 canvas ImageData 生成图像
cv.matFromImageData(imgData) - mat
size(cv.size): 图像尺寸
rows(number): 图像高度
cols(number): 图像宽度
type(number): 图像类型(cv.CV_8UC3 ...)
scalar(cv.Scalar): 图像初始值
array(Array): JS 图像数组
imgData(ImageData): canvas 图像数据
mat(cv.Mat): 图像(type)
获取图像属性
// 图像高度
mat.rows -> rows
// 图像宽度
mat.cols -> cols
// 图像尺寸
mat.size() -> size
// 图像通道数量
mat.channels() -> channels
// 图像数据类型
mat.type() -> type
mat(cv.Mat): 图像
rows(number): 图像高度
cols(number): 图像宽度
size(cv.Size): 图像尺寸
channles(number): 图像通道数量
type(number): 图像数据类型(cv.CV_8UC3 ...)
获取图像数据
mat.data -> data
mat.data8S -> data8S
mat.data16U -> data16U
mat.data16S -> data16S
mat.data32S -> data32S
mat.data32F -> data32F
mat.data64F -> data64F
mat(cv.Mat): 图像
data(Uint8Array): 无符号 8 位整型数据
data8S(Int8Array): 有符号 8 位整型数据
data16U(Uint16Array): 无符号 16 位整型数据
data16S(Int16Array): 有符号 16 位整型数据
data32S(Int32Array): 有符号 32 位整型数据
data32F(Float32Array): 32 位浮点数据
data64F(Float64Array): 64 位浮点数据
裁切图像
mat.roi(rect) -> matROI
rect(cv.Rect): 图像裁切区域
matROI(cv.Mat): 裁切图像
颜色空间转换
cv.cvtColor(src, dst, code)
src(cv.Mat): 输入图像
dst(cv.Mat): 输出图像
code(number): 转换类型(cv.COLOR_RGBA2RGB ...)
图像缩放
cv.resize(src, dst, dsize, fx, fy, interpolation)
src(cv.Mat): 输入图像
dst(cv.Mat): 输出图像
dsize(cv.Size): 目标尺寸
fx(number): x 轴缩放因子
fy(number): y 轴缩放因子
interpolation(number): 插值类型(cv.INTER_LINEAR ...)
创建图像向量
new cv.MatVector() -> matVector
matVector(cv.MatVector): 图像向量
图像向量操作
// 添加
matVector.push_back(mat)
// 获取
matVector.get(index) -> mat
// 设置
matVector.set(index, mat)
matVector(cv.MatVector): 图像向量
mat(cv.Mat): 图像
index(number): 索引值
通道拆分与合并
// 拆分
cv.split(src, channels)
// 合并
cv.merge(channels, dst)
src(cv.Mat): 输入图像
dst(cv.Mat): 输出图像
channels(cv.MatVector): 通道图像向量
删除对象
// 删除图像对象
mat.delete()
// 删除图像向量对象
matVector.delete()
mat(cv.Mat): 图像
matVector(cv.MatVector): 图像向量
创建视频流
new cv.VideoCapture(videoSource) -> cap
videoSource(Dom/string): video 标签或其 id
cap(cv.VideoCapture): 视频流
读取视频帧
cap.read(mat)
cap(cv.VideoCapture): 视频流
mat(cv.Mat): 图像
一个使用Opencv.js的页面
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Hello OpenCV.js</title>
</head>
<body>
<h2>Hello OpenCV.js</h2>
<p id="status">OpenCV.js is loading...</p>
<div>
<div class="inputoutput">
<img id="imageSrc" alt="No Image" />
<div class="caption">imageSrc <input type="file" id="fileInput" name="file" /></div>
</div>
<div class="inputoutput">
<canvas id="canvasOutput" ></canvas>
<div class="caption">canvasOutput</div>
</div>
</div>
<script type="text/javascript">
let imgElement = document.getElementById('imageSrc');
let inputElement = document.getElementById('fileInput');
inputElement.addEventListener('change', (e) => {
imgElement.src = URL.createObjectURL(e.target.files[0]);
}, false);
imgElement.onload = function() {
let mat = cv.imread(imgElement);
cv.imshow('canvasOutput', mat);
mat.delete();
};
function onOpenCvReady() {
document.getElementById('status').innerHTML = 'OpenCV.js is ready.';
}
</script>
<script async src="opencv.js" onload="onOpenCvReady();" type="text/javascript"></script>
</body>
</html>
构建过程
安装Emscripten SDK
git clone https://github.com/juj/emsdk.git
cd emsdk
./emsdk install latest
./emsdk activate latest
source ./emsdk_env.sh
获取OpenCV
wget https://github.com/opencv/opencv/archive/3.4.1.zip
unzip 3.4.1.zip
cd opencv-3.4.1
# 将OpenCV编译为WASM版本
python ./platform/js/build_js.py build_wasm --build_wasm
下一篇:Three.JS笔记