mirror of https://github.com/opencv/opencv.git
Merge pull request #25496 from Kumataro:fix25495
highgui: wayland: show "NO" status if dependency is missing #25496 Close #25495 - [doc] Add document to enable Wayland highgui-backend in ubuntu 24.04. - [build] Show "NO" status instead of version if dependency library is missing. - [build] Fix to find Wayland EGL. - [fix] Add some callback stub functions to suppress build warning. ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [ ] I agree to contribute to the project under Apache 2 License. - [ ] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [ ] The PR is proposed to the proper branch - [ ] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMakepull/25510/head
parent
b1e01970ef
commit
2a2ff55257
6 changed files with 177 additions and 18 deletions
@ -0,0 +1,106 @@ |
||||
Using Wayland highgui-backend in Ubuntu {#tutorial_wayland_ubuntu} |
||||
======================================= |
||||
|
||||
@tableofcontents |
||||
|
||||
@prev_tutorial{tutorial_intelperc} |
||||
|
||||
| | | |
||||
| -: | :- | |
||||
| Original author | Kumataro | |
||||
| Compatibility | OpenCV >= 4.10 | |
||||
| ^ | Ubuntu 24.04 | |
||||
|
||||
Goal |
||||
----- |
||||
This tutorial is to use Wayland highgui-backend in Ubuntu 24.04. |
||||
|
||||
Wayland highgui-backend is experimental implementation. |
||||
|
||||
Setup |
||||
----- |
||||
- Setup Ubuntu 24.04. |
||||
- `sudo apt install build-essential git cmake` to build OpenCV. |
||||
- `sudo apt install libwayland-dev wayland-protocols libxkbcommon-dev` to enable Wayland highgui-backend. |
||||
- (Option) `sudo apt install ninja-build` (or remove `-GNinja` option for cmake command). |
||||
- (Option) `sudo apt install libwayland-egl1` to enable Wayland EGL library. |
||||
|
||||
Get OpenCV from GitHub |
||||
---------------------- |
||||
|
||||
```bash |
||||
mkdir work |
||||
cd work |
||||
git clone --depth=1 https://github.com/opencv/opencv.git |
||||
``` |
||||
|
||||
@note |
||||
`--depth=1` option is to limit downloading commits. If you want to see more commit history, please remove this option. |
||||
|
||||
Build/Install OpenCV with Wayland highgui-backend |
||||
------------------------------------------------- |
||||
|
||||
Run `cmake` with `-DWITH_WAYLAND=ON` option to configure OpenCV. |
||||
|
||||
```bash |
||||
cmake -S opencv -B build4-main -DWITH_WAYLAND=ON -GNinja |
||||
``` |
||||
|
||||
If succeeded, Wayland Client/Cursor/Protocols and Xkbcommon versions are shown. Wayland EGL is option. |
||||
|
||||
```plaintext |
||||
-- |
||||
-- GUI: Wayland |
||||
-- Wayland: (Experimental) YES |
||||
-- Wayland Client: YES (ver 1.22.0) |
||||
-- Wayland Cursor: YES (ver 1.22.0) |
||||
-- Wayland Protocols: YES (ver 1.34) |
||||
-- Xkbcommon: YES (ver 1.6.0) |
||||
-- Wayland EGL(Option): YES (ver 18.1.0) |
||||
-- GTK+: NO |
||||
-- VTK support: NO |
||||
``` |
||||
|
||||
Run `cmake --build` to build, and `sudo cmake --install` to install into your system. |
||||
|
||||
```bash |
||||
cmake --build build4-main |
||||
sudo cmake --install build4-main |
||||
sudo ldconfig |
||||
``` |
||||
|
||||
Simple Application to try Wayland highgui-backend |
||||
------------------------------------------------- |
||||
Try this code, so you can see name of currentUIFrramework() and OpenCV logo window with Wayland highgui-backend. |
||||
|
||||
|
||||
```bash |
||||
// g++ main.cpp -o a.out -I /usr/local/include/opencv4 -lopencv_core -lopencv_highgui -lopencv_imgcodecs |
||||
#include <opencv2/core.hpp> |
||||
#include <opencv2/highgui.hpp> |
||||
#include <opencv2/imgcodecs.hpp> |
||||
#include <iostream> |
||||
#include <string> |
||||
|
||||
int main(void) |
||||
{ |
||||
std::cout << "cv::currentUIFramework() returns " << cv::currentUIFramework() << std::endl; |
||||
|
||||
cv::Mat src; |
||||
src = cv::imread("opencv-logo.png"); |
||||
|
||||
cv::namedWindow("src"); |
||||
|
||||
int key = 0; |
||||
do |
||||
{ |
||||
cv::imshow("src", src ); |
||||
key = cv::waitKey(50); |
||||
} while( key != 'q' ); |
||||
return 0; |
||||
} |
||||
``` |
||||
|
||||
Limitation/Known problem |
||||
------------------------ |
||||
- cv::moveWindow() is not implementated. ( See. https://github.com/opencv/opencv/issues/25478 ) |
Loading…
Reference in new issue