Skip to content

Commit 39b856e

Browse files
committed
Added Wayland plugin to Qt backend.
1 parent 736b905 commit 39b856e

File tree

7 files changed

+31
-21
lines changed

7 files changed

+31
-21
lines changed

.github/workflows/build_wheels_linux.yml

+2-2
Original file line numberDiff line numberDiff line change
@@ -41,7 +41,7 @@ jobs:
4141
MB_ML_VER: 2014
4242
TRAVIS_BUILD_DIR: ${{ github.workspace }}
4343
CONFIG_PATH: travis_config.sh
44-
DOCKER_IMAGE: quay.io/opencv-ci/opencv-python-manylinux2014-x86-64:20230117
44+
DOCKER_IMAGE: quay.io/opencv-ci/opencv-python-manylinux2014-x86-64:20230124
4545
USE_CCACHE: 0
4646
UNICODE_WIDTH: 32
4747
PLAT: x86_64
@@ -139,7 +139,7 @@ jobs:
139139
NP_TEST_DEP: numpy==1.19.4
140140
TRAVIS_BUILD_DIR: ${{ github.workspace }}
141141
CONFIG_PATH: travis_config.sh
142-
DOCKER_IMAGE: quay.io/opencv-ci/opencv-python-manylinux2014-x86-64:20230117
142+
DOCKER_IMAGE: quay.io/opencv-ci/opencv-python-manylinux2014-x86-64:20230124
143143
USE_CCACHE: 1
144144
UNICODE_WIDTH: 32
145145
SDIST: ${{ matrix.build_sdist || 0 }}

.github/workflows/build_wheels_linux_arm.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,7 @@ jobs:
4242
MB_ML_VER: 2014
4343
TRAVIS_BUILD_DIR: ${{ github.workspace }}
4444
CONFIG_PATH: travis_config.sh
45-
DOCKER_IMAGE: quay.io/opencv-ci/opencv-python-manylinux2014-aarch64:20230117
45+
DOCKER_IMAGE: quay.io/opencv-ci/opencv-python-manylinux2014-aarch64:20230124
4646
USE_CCACHE: 0
4747
UNICODE_WIDTH: 32
4848
SDIST: ${{ matrix.build_sdist || 0 }}

docker/manylinux2014/Dockerfile_aarch64

+8-8
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
# Version: 20230117
1+
# Version: 20230124
22
# Image name: quay.io/opencv-ci/opencv-python-manylinux2014-aarch64
33

44
FROM quay.io/pypa/manylinux2014_aarch64:latest
@@ -9,13 +9,13 @@ ARG FREETYPE_VERSION=2.12.1
99
ARG LIBPNG_VERSION=1.6.37
1010
ARG NASM_VERSION=2.15.04
1111
ARG OPENSSL_VERSION=1_1_1s
12-
ARG QT_VERSION=5.15.0
12+
ARG QT_VERSION=5.15.8
1313
ARG YASM_VERSION=1.3.0
1414

1515
ENV LD_LIBRARY_PATH /usr/local/lib:$LD_LIBRARY_PATH
1616

1717
# epel-release need for aarch64 to get openblas packages
18-
RUN yum install zlib-devel curl-devel xcb-util-renderutil-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-wm-devel mesa-libGL-devel libxkbcommon-devel libxkbcommon-x11-devel libXi-devel lapack-devel epel-release -y && \
18+
RUN yum install zlib-devel curl-devel xcb-util-renderutil-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-wm-devel mesa-libGL-devel libxkbcommon-devel libxkbcommon-x11-devel libXi-devel lapack-devel epel-release wayland-devel libwayland-egl -y && \
1919
yum install openblas-devel dejavu-sans-fonts -y && \
2020
cp /usr/include/lapacke/lapacke*.h /usr/include/ && \
2121
curl https://raw.githubusercontent.com/xianyi/OpenBLAS/v0.3.3/cblas.h -o /usr/include/cblas.h && \
@@ -44,13 +44,12 @@ RUN mkdir ~/freetype_sources && \
4444
cd .. && \
4545
rm -rf ~/freetype_sources
4646

47-
RUN curl -O -L https://download.qt.io/official_releases/qt/5.15/${QT_VERSION}/single/qt-everywhere-src-${QT_VERSION}.tar.xz && \
48-
tar -xf qt-everywhere-src-${QT_VERSION}.tar.xz && \
47+
RUN curl -O -L https://download.qt.io/archive/qt/5.15/${QT_VERSION}/single/qt-everywhere-opensource-src-${QT_VERSION}.tar.xz && \
48+
tar -xf qt-everywhere-opensource-src-${QT_VERSION}.tar.xz && \
4949
cd qt-everywhere-src-${QT_VERSION} && \
5050
export MAKEFLAGS=-j$(nproc) && \
51-
./configure -prefix /opt/Qt${QT_VERSION} -release -opensource -confirm-license -qtnamespace QtOpenCVPython -xcb -xcb-xlib -bundled-xcb-xinput -no-openssl -no-dbus -skip qt3d -skip qtactiveqt -skip qtcanvas3d -skip qtconnectivity -skip qtdatavis3d -skip qtdoc -skip qtgamepad -skip qtgraphicaleffects -skip qtimageformats -skip qtlocation -skip qtmultimedia -skip qtpurchasing -skip qtqa -skip qtremoteobjects -skip qtrepotools -skip qtscript -skip qtscxml -skip qtsensors -skip qtserialbus -skip qtserialport -skip qtspeech -skip qttranslations -skip qtwayland -skip qtwebchannel -skip qtwebengine -skip qtwebsockets -skip qtwebview -skip xmlpatterns -skip declarative -make libs && \
52-
make && \
53-
make install && \
51+
./configure -prefix /opt/Qt${QT_VERSION} -release -opensource -confirm-license -qtnamespace QtOpenCVPython -xcb -xcb-xlib -bundled-xcb-xinput -no-openssl -no-dbus -skip qt3d -skip qtactiveqt -skip qtcanvas3d -skip qtconnectivity -skip qtdatavis3d -skip qtdoc -skip qtgamepad -skip qtgraphicaleffects -skip qtimageformats -skip qtlocation -skip qtmultimedia -skip qtpurchasing -skip qtqa -skip qtremoteobjects -skip qtrepotools -skip qtscript -skip qtscxml -skip qtsensors -skip qtserialbus -skip qtserialport -skip qtspeech -skip qttranslations -skip qtwebchannel -skip qtwebengine -skip qtwebsockets -skip qtwebview -skip xmlpatterns -skip declarative -make libs && \
52+
make && make install && \
5453
cd .. && \
5554
rm -rf qt-everywhere*
5655

@@ -139,3 +138,4 @@ RUN git config --global --add safe.directory /io
139138
ENV PKG_CONFIG_PATH /usr/local/lib/pkgconfig:/ffmpeg_build/lib/pkgconfig
140139
ENV LDFLAGS -L/ffmpeg_build/lib
141140
ENV PATH "$HOME/bin:$PATH"
141+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/opt/Qt${QT_VERSION}/lib

docker/manylinux2014/Dockerfile_x86_64

+7-7
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
# Version: 20230117
1+
# Version: 20230124
22
# Image name: quay.io/opencv-ci/opencv-python-manylinux2014-x86-64
33

44
FROM quay.io/pypa/manylinux2014_x86_64:latest
@@ -15,7 +15,7 @@ ARG YASM_VERSION=1.3.0
1515
ENV LD_LIBRARY_PATH /usr/local/lib:$LD_LIBRARY_PATH
1616

1717
# epel-release need for aarch64 to get openblas packages
18-
RUN yum install zlib-devel curl-devel xcb-util-renderutil-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-wm-devel mesa-libGL-devel libxkbcommon-devel libxkbcommon-x11-devel libXi-devel lapack-devel epel-release -y && \
18+
RUN yum install zlib-devel curl-devel xcb-util-renderutil-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-wm-devel mesa-libGL-devel libxkbcommon-devel libxkbcommon-x11-devel libXi-devel lapack-devel epel-release wayland-devel libwayland-egl -y && \
1919
yum install openblas-devel dejavu-sans-fonts -y && \
2020
cp /usr/include/lapacke/lapacke*.h /usr/include/ && \
2121
curl https://raw.githubusercontent.com/xianyi/OpenBLAS/v0.3.3/cblas.h -o /usr/include/cblas.h && \
@@ -44,13 +44,12 @@ RUN mkdir ~/freetype_sources && \
4444
cd .. && \
4545
rm -rf ~/freetype_sources
4646

47-
RUN curl -O -L https://download.qt.io/official_releases/qt/5.15/${QT_VERSION}/single/qt-everywhere-src-${QT_VERSION}.tar.xz && \
48-
tar -xf qt-everywhere-src-${QT_VERSION}.tar.xz && \
47+
RUN curl -O -L https://download.qt.io/archive/qt/5.15/${QT_VERSION}/single/qt-everywhere-opensource-src-${QT_VERSION}.tar.xz && \
48+
tar -xf qt-everywhere-opensource-src-${QT_VERSION}.tar.xz && \
4949
cd qt-everywhere-src-${QT_VERSION} && \
5050
export MAKEFLAGS=-j$(nproc) && \
51-
./configure -prefix /opt/Qt${QT_VERSION} -release -opensource -confirm-license -qtnamespace QtOpenCVPython -xcb -xcb-xlib -bundled-xcb-xinput -no-openssl -no-dbus -skip qt3d -skip qtactiveqt -skip qtcanvas3d -skip qtconnectivity -skip qtdatavis3d -skip qtdoc -skip qtgamepad -skip qtgraphicaleffects -skip qtimageformats -skip qtlocation -skip qtmultimedia -skip qtpurchasing -skip qtqa -skip qtremoteobjects -skip qtrepotools -skip qtscript -skip qtscxml -skip qtsensors -skip qtserialbus -skip qtserialport -skip qtspeech -skip qttranslations -skip qtwayland -skip qtwebchannel -skip qtwebengine -skip qtwebsockets -skip qtwebview -skip xmlpatterns -skip declarative -make libs && \
52-
make && \
53-
make install && \
51+
./configure -prefix /opt/Qt${QT_VERSION} -release -opensource -confirm-license -qtnamespace QtOpenCVPython -xcb -xcb-xlib -bundled-xcb-xinput -no-openssl -no-dbus -skip qt3d -skip qtactiveqt -skip qtcanvas3d -skip qtconnectivity -skip qtdatavis3d -skip qtdoc -skip qtgamepad -skip qtgraphicaleffects -skip qtimageformats -skip qtlocation -skip qtmultimedia -skip qtpurchasing -skip qtqa -skip qtremoteobjects -skip qtrepotools -skip qtscript -skip qtscxml -skip qtsensors -skip qtserialbus -skip qtserialport -skip qtspeech -skip qttranslations -skip qtwebchannel -skip qtwebengine -skip qtwebsockets -skip qtwebview -skip xmlpatterns -skip declarative -make libs && \
52+
make && make install && \
5453
cd .. && \
5554
rm -rf qt-everywhere*
5655

@@ -139,3 +138,4 @@ RUN git config --global --add safe.directory /io
139138
ENV PKG_CONFIG_PATH /usr/local/lib/pkgconfig:/ffmpeg_build/lib/pkgconfig
140139
ENV LDFLAGS -L/ffmpeg_build/lib
141140
ENV PATH "$HOME/bin:$PATH"
141+
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/opt/Qt${QT_VERSION}/lib

patches/patchQtPlugins

+1-1
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ index 4c0b3880fc..dffa0a4caa 100644
99
+ install(DIRECTORY ${Qt5_DIR}/../../../plugins DESTINATION lib/qt)
1010
+ endif()
1111
+ if(UNIX AND NOT APPLE)
12-
+ install(DIRECTORY /opt/Qt5.15.0/plugins DESTINATION lib/qt)
12+
+ install(DIRECTORY /opt/Qt5.15.8/plugins DESTINATION lib/qt)
1313
+ install(DIRECTORY /usr/share/fonts DESTINATION lib/qt)
1414
+ endif()
1515
if(HAVE_QT_OPENGL)

setup.py

+12-1
Original file line numberDiff line numberDiff line change
@@ -223,7 +223,18 @@ def main():
223223

224224
if sys.platform.startswith("linux"):
225225
rearrange_cmake_output_data["cv2.qt.plugins.platforms"] = [
226-
(r"lib/qt/plugins/platforms/libqxcb\.so")
226+
(r"lib/qt/plugins/platforms/libqxcb\.so"),
227+
228+
# wayland plugin parts
229+
(r"lib/qt/plugins/platforms/libqwayland-generic\.so"),
230+
(r"lib/qt/plugins/platforms/wayland-decoration-client/libbradient\.so"),
231+
(r"lib/qt/plugins/platforms/wayland-graphics-integration-client/libshm-emulation-server\.so"),
232+
(r"lib/qt/plugins/platforms/wayland-shell-integration/libfullscreen-shell-v1\.so"),
233+
(r"lib/qt/plugins/platforms/wayland-shell-integration/libivi-shell\.so"),
234+
(r"lib/qt/plugins/platforms/wayland-shell-integration/libwl-shell\.so"),
235+
(r"lib/qt/plugins/platforms/wayland-shell-integration/libxdg-shell\.so"),
236+
(r"lib/qt/plugins/platforms/wayland-shell-integration/libxdg-shell-v5\.so"),
237+
(r"lib/qt/plugins/platforms/wayland-shell-integration/libxdg-shell-v6\.so")
227238
]
228239

229240
# add fonts for Qt5

travis_config.sh

-1
Original file line numberDiff line numberDiff line change
@@ -34,7 +34,6 @@ if [ -n "$IS_OSX" ]; then
3434
export MAKEFLAGS="-j$(sysctl -n hw.ncpu)"
3535
else
3636
echo " > Linux environment "
37-
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/opt/Qt5.15.0/lib
3837
export MAKEFLAGS="-j$(grep -E '^processor[[:space:]]*:' /proc/cpuinfo | wc -l)"
3938
CURRENT_ARCH=$(uname -m)
4039
if [[ $CURRENT_ARCH == 'aarch64' ]]; then

0 commit comments

Comments
 (0)