krab22
krab2203 травня 2018 р. 06:16

Проблема с запуском Qt5 приложения

Qt5

При запуске приложения выводится:

This application failed to start because it could not find or load the Qt platform plugin "xcb" in "".
Available platform plugins are: xcb.
Reinstalling the application may fix this problem

Платформа Fedora 22.

Плагин есть. ldd находит все библиотеки. Не запускается только под простым пользователем. Под рутом и другим пользователем-администратором все стартует нормально.

На первый взгляд - не хватает каких то прав...

Но каких???

Помогите!!!

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

13
Evgenii Legotckoi
  • 03 травня 2018 р. 06:20

Попробуйте добавить в pro-файл вот эти настройки

linux {
    QT       += x11extras
    CONFIG   += link_pkgconfig
    PKGCONFIG += x11
}
    krab22
    • 03 травня 2018 р. 07:00

    а можно по подробнее про то, что вы написали - что к чему?

      Evgenii Legotckoi
      • 03 травня 2018 р. 07:09

      Ну у вас в проекте должен быть .pro файл, когда вы пишите приложение. В этот pro-файл необходимо прописать данные строчки.

      В данном случае включается поддержка расширений для x11, в том числе и поддержка библиотек xcb. Само собой библиотеки должны быть установлены.

      Или ваш вопрос не связан с программированием?
        krab22
        • 03 травня 2018 р. 07:17

        Вопрос то связан.. и я отлично понимаю что такое файл проекта - хотя в Qt новичок,
        но не понятно что такое и x11extras и зачем это нужно.
        Если нужна еще какая то библиотека, то почему под другими пользователями(пользователями с расширенными наборами прав) все стартует за милу душу?

          Evgenii Legotckoi
          • 03 травня 2018 р. 07:30
          • (відредаговано)

          Вот цитата из официальной документации

          Qt X11 Extras позволяет программисту Qt писать приложения для платформы Linux/X11. Приложения, разработанные с помощью Qt, также могут быть развернуты в нескольких других настольных и встроенных операционных системах без необходимости переписывать исходный код
          Для использования xcb нужно включать поддержку данного расширения.

          PKGCONFIG - нужен чтобы найти эти библиотеки, в обычном варианте они могут не находиться. Скорее всего ваш случай. В своё время я нашёл это решение, а до запуска из-под рута не доходил.

          То, что находит из под рута... ну так под рутом и прав на доступ больше, для конкретного пользователя значит библиотеки недоступны или не установлены.
            krab22
            • 03 травня 2018 р. 07:40

            Спасибо за разъяснения!
            Как я понял XCB используется для отлова нажатия горячих клавиш в X11. Т.е. указанная Вами добавка к проекту необходимо если я использую компоненты с HotKey (например QAction). И соответственно в данном случае требуется подключение x11extras.
            Я правильно понял?

            А как на Wayland - тоже требуется ее подключать?

            Про рута... Работает и не из под рута - у пользователей входящих в группу администраторов - далеко не root.

              Evgenii Legotckoi
              • 03 травня 2018 р. 07:46

              мм... хоткеи и так будут работать, но в рамках приложения, а вот если вам нужны глобальные хоткеи (когда приложение свёрнуто в трей например)... вот тогда потребуется xcb или иные платформозависимые решения. Qt не предостовляет решения для глобальных хоткеев.

              Я в своё время занимался данным вопросом, как результат, написал небольшую утилиту для глобальных хоткеев, которая работает под WinAPI и Linux/x11 - это QGlobalShortcut

              Насчёт Wayland не обладаю актуальной информацией, но вроде как пока что требуется xcb.

              Насчёт администраторов, в любом случае прав-то больше. здесь нужно разгребать, куда у них доступ есть и т.д., тогда возможно получите полноценный ответ, но это вам нужно у себя смотреть, что, да как.
                krab22
                • 03 травня 2018 р. 07:51

                ок! Спасибо!
                Просто хотелось бы понять когда это подключение требуется, а когда нет.
                Завтра попробую. Отпишусь

                  Evgenii Legotckoi
                  • 03 травня 2018 р. 07:55

                  По факту это подключение требуется тогда, когда вы начинаете подключать заголовочные файлы x-библиотек.

                  Вот здесь полный список и минимальные версии таких библиотек.
                  Также класс QX11Info требует настройки x11extras .

                  В остальных случаях не должны требоваться такие настройки.
                    krab22
                    • 03 травня 2018 р. 22:30

                    В общем то логично. А какие элементы GUI(и сопутствующих типов) используют X-библиотеки? Список таких элементов есть?

                      krab22
                      • 03 травня 2018 р. 22:48

                      Сделал по Вашим рекомендациям - нет фифекта(кроме зависимости еще от одной библиотеки).... :-(
                      Все таки проблема кроется, на мой взгляд, где то в правах....
                      Но где? и в каких правах?

                        Evgenii Legotckoi
                        • 07 травня 2018 р. 06:04

                        Я бы отталкивался от того списка библиотек, которые я привёл в предыдущем сообщений. Просто почитать описание, какая библиотека и за что отвечает. Но я бы на вашем месте не запаривался на этот счёт до тех пор, пока не встанет конкретная проблема/задача. Там уже достаточно сразу будет ясно, что если что-то не так, то нужно будет использовать что-то платформозависимое.


                        Что касается GUI, то всё, что уже реализовано в QWidgets/Qt Quick (в плане отрисовки внешнего вида и т.д.) не должно требовать какого-то функционала из x11extras .
                          Evgenii Legotckoi
                          • 07 травня 2018 р. 06:07

                          Не знаю, честно, я работал с тем, что требовало xcb, но такой проблемы с правами не имел. Может это какой-то такой прикол Fedora, но не могу сказать, я работаю с Ubuntu и KDE Neon, который в свою очередь базируется на Ubuntu.

                            Коментарі

                            Only authorized users can post comments.
                            Please, Log in or Sign up
                            m
                            • molni99
                            • 26 жовтня 2024 р. 08:37

                            C++ - Тест 004. Указатели, Массивы и Циклы

                            • Результат:80бали,
                            • Рейтинг балів4
                            m
                            • molni99
                            • 26 жовтня 2024 р. 08:29

                            C++ - Тест 004. Указатели, Массивы и Циклы

                            • Результат:20бали,
                            • Рейтинг балів-10

                            C++ - Тест 003. Условия и циклы

                            • Результат:42бали,
                            • Рейтинг балів-8
                            Останні коментарі
                            A
                            ALO1ZE19 жовтня 2024 р. 15:19
                            Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                            ИМ
                            Игорь Максимов05 жовтня 2024 р. 14:51
                            Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                            d
                            dblas505 липня 2024 р. 18:02
                            QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                            k
                            kmssr09 лютого 2024 р. 02:43
                            Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                            АК
                            Анатолий Кононенко05 лютого 2024 р. 09:50
                            Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                            Тепер обговоріть на форумі
                            jd
                            jasmine disouza28 жовтня 2024 р. 11:58
                            GeForce Now India: Unlocking the Future of Cloud Gaming GeForce Now India has a major impact on the gaming scene by introducing NVIDIA's cloud gaming service to Indian gamers. GeForce Now India lets you stream top-notch PC games on any device, from b…
                            9
                            9Anonim25 жовтня 2024 р. 16:10
                            Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                            J
                            JacobFib17 жовтня 2024 р. 10:27
                            добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                            ИМ
                            Игорь Максимов03 жовтня 2024 р. 11:05
                            Реализация навигации по разделам Спасибо Евгений!
                            JW
                            Jhon Wick01 жовтня 2024 р. 22:52
                            Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…

                            Слідкуйте за нами в соціальних мережах