本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

,适用于Linux、macOS和Windows系统,旨在使Go语言成为与OpenCV生态系统最新发展兼容的“一等”客户端。
GoCV支持使用Nvidia GPU的CUDA硬件加速,详情参见CUDA README;同时支持Intel OpenVINO工具包,详情参见OpenVINO README。
以下示例打开设备“0”(通常为默认摄像头),读取视频帧并在GUI窗口显示:
package main import ( "gocv.io/x/gocv" ) func main() { webcam, _ := gocv.OpenVideoCapture(0) window := gocv.NewWindow("Hello") img := gocv.NewMat() for { webcam.Read(&img) window.IMShow(img) window.WaitKey(1) } }
!GoCV
该示例打开摄像头,使用级联分类器检测人脸并绘制绿色矩形框:
package main import ( "fmt" "image/color" "gocv.io/x/gocv" ) func main() { // 设置使用视频捕获设备0 deviceID := 0 // 打开摄像头 webcam, err := gocv.OpenVideoCapture(deviceID) if err != nil { fmt.Println(err) return } defer webcam.Close() // 打开显示窗口 window := gocv.NewWindow("Face Detect") defer window.Close() // 准备图像矩阵 img := gocv.NewMat() defer img.Close() // 人脸检测框颜色(蓝色) blue := color.RGBA{0, 0, 255, 0} // 加载人脸分类器 classifier := gocv.NewCascadeClassifier() defer classifier.Close() if !classifier.Load("data/haarcascade_frontalface_default.xml") { fmt.Println("错误:无法读取分类器文件 data/haarcascade_frontalface_default.xml") return } fmt.Printf("开始读取摄像头设备: %v\n", deviceID) for { if ok := webcam.Read(&img); !ok { fmt.Printf("无法读取设备 %v\n", deviceID) return } if img.Empty() { continue } // 检测人脸 rects := classifier.DetectMultiScale(img) fmt.Printf("发现 %d 个人脸\n", len(rects)) // 在图像上绘制人脸矩形框 for _, r := range rects { gocv.Rectangle(&img, r, blue, 3) } // 在窗口显示图像,等待1毫秒 window.IMShow(img) window.WaitKey(1) } }
项目cmd目录提供多种实用命令行工具示例:
安装GoCV前需先安装匹配版本的OpenCV(当前需OpenCV 4.5.3),以下是各系统安装指南。
克隆仓库:
cd $HOME/folder/with/your/src/ git clone [***] cd gocv
使用Makefile安装OpenCV 4.5.3:
make install
如需静态库:
make install BUILD_SHARED_LIBS=OFF
成功安装后将显示:
gocv version: 0.28.0 opencv lib version: 4.5.3
参见cuda目录获取详细说明。
cd $HOME/folder/with/gocv/ make install_all
如需静态库:
make install_all BUILD_SHARED_LIBS=OFF
cd $HOME/src/gocv.io/x/gocv go run ./cmd/version/main.go
应输出:
gocv version: 0.28.0 opencv lib version: 4.5.3
禁用pkg-config自动配置,手动设置CGO环境变量:
export CGO_CPPFLAGS="-I/usr/local/include" export CGO_LDFLAGS="-L/usr/local/lib -lopencv_core -lopencv_face -lopencv_videoio -lopencv_imgproc -lopencv_highgui -lopencv_imgcodecs -lopencv_objdetect -lopencv_features2d -lopencv_video -lopencv_dnn -lopencv_xfeatures2d" go run -tags customenv ./cmd/version/main.go
安装Homebrew后执行:
brew install opencv pkgconfig
验证安装:
cd $HOME/folder/with/your/src/gocv go run ./cmd/version/main.go
C:\Program Files\mingw-w64\x86_64-7.3.0-posix-seh-rt_v5-rev2\mingw64\binchdir %GOPATH%\src\gocv.io\x\gocv win_build_opencv.cmd
C:\opencv\build\install\x64\mingw\bingo run cmd\version\main.go
cd $HOME/folder/with/your/src/ git clone [***] cd gocv make install_raspi
项目提供Dockerfile,可通过Makefile快速构建:
make docker
指定Go版本:
make docker GOVERSION='1.15'
安装依赖:
brew cask install xquartz brew install socat
安装后需注销并重新登录
配置XQuartz:
启动socat代理:
socat TCP-LISTEN:6000,reuseaddr,fork UNIX-CLIENT:\"$DISPLAY\"
运行容器:
docker run -it --rm -e DISPLAY=docker.for.mac.host.internal:0 your-gocv-app
注意:Docker for Mac不支持摄像头设备,无法运行依赖摄像头的应用
GoCV的Mat对象需显式关闭以避免内存泄漏,可使用-tags matprofile构建标签启用内存分析:
go run -tags matprofile cmd/version/main.go
通过gocv.MatProfile.Count()获取未释放Mat数量,或集成HTTP调试接口监控:
import _ "net/http/pprof" // 启动HTTP服务后访问 http://localhost:6060/debug/pprof/gocv.io/x/gocv.Mat
===FULL_DESC===# GoCV
,适用于Linux、macOS和Windows系统,旨在使Go语言成为与OpenCV生态系统最新发展兼容的"一等"客户端。
GoCV支持使用Nvidia GPU的CUDA硬件加速,详情参见CUDA README;同时支持Intel OpenVINO工具包,详情参见OpenVINO README。
以下示例打开设备"0"(通常为默认摄像头),读取视频帧并在GUI窗口显示:
package main import ( "gocv.io/x/gocv" ) func main() { webcam, _ := gocv.OpenVideoCapture(0) window := gocv.NewWindow("Hello") img := gocv.NewMat() for { webcam.Read(&img) window.IMShow(img) window.WaitKey(1) } }
!GoCV
该示例打开摄像头,使用级联分类器检测人脸并绘制绿色矩形框:
package main import ( "fmt" "image/color" "gocv.io/x/gocv" ) func main() { // 设置使用视频捕获设备0 deviceID := 0 // 打开摄像头 webcam, err := gocv.OpenVideoCapture(deviceID) if err != nil { fmt.Println(err) return } defer webcam.Close() // 打开显示窗口 window := gocv.NewWindow("Face Detect") defer window.Close() // 准备图像矩阵 img := gocv.NewMat() defer img.Close() // 人脸检测框颜色(蓝色) blue := color.RGBA{0, 0, 255, 0} // 加载人脸分类器 classifier := gocv.NewCascadeClassifier() defer classifier.Close() if !classifier.Load("data/haarcascade_frontalface_default.xml") { fmt.Println("错误:无法读取分类器文件 data/haarcascade_frontalface_default.xml") return } fmt.Printf("开始读取摄像头设备: %v\n", deviceID) for { if ok := webcam.Read(&img); !ok { fmt.Printf("无法读取设备 %v\n", deviceID) return } if img.Empty() { continue } // 检测人脸 rects := classifier.DetectMultiScale(img) fmt.Printf("发现 %d 个人脸\n", len(rects)) // 在图像上绘制人脸矩形框 for _, r := range rects { gocv.Rectangle(&img, r, blue, 3) } // 在窗口显示图像,等待1毫秒 window.IMShow(img) window.WaitKey(1) } }
项目cmd目录提供多种实用命令行工具示例:
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429