Подключение проигрывателя ютуб
Подключаю проигрыватель ютуба в QML. Для этого в main.qml размещаю
WebView {
anchors.fill: parent
url: initialUrl + “?” + “PjFuEGSTjPk”
}
где – initialUrl идет из main.cpp в виде
QUrl initialUrl = QUrl::fromUserInput(QStringLiteral(“qrc://content/player.html”));
context->setContextProperty(QStringLiteral(“initialUrl”), initialUrl);
в ссылке player.html – это страница самосозданная и помещенная рядом с main.qml. В эту страницу по апи ютуба вшит плеер ихний.
Так вот… При запуске на компе все ок. Все работает и показывается видео. Но как только я пытаюсь запустить на мобилке, то говорит мол неможет открыть страницу по такому адресу.
Что я не то для мобилки сделал. Может где не подключил фаайл это самосозданный?
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!
Пікірлер
- Ora Iro
- Жел. 24, 2024, 6:38 Т.Ж.
C++ - Тест 001. Первая программа и типы данных
- Нәтиже:40ұпай,
- Бағалау ұпайлары-8
- Akiv Doros
- Қар. 11, 2024, 2:58 Т.Қ.
C++ - Тест 004. Указатели, Массивы и Циклы
- Нәтиже:50ұпай,
- Бағалау ұпайлары-4
- molni99
- Қаз. 26, 2024, 1:37 Т.Ж.
C++ - Тест 004. Указатели, Массивы и Циклы
- Нәтиже:80ұпай,
- Бағалау ұпайлары4
Вон, WebEngine есть же для MSVC компилятора, а для MinGW пока ещё не сделали. Так что в этом глюки могут быть.
Насколько знаю, по дефолту ютубовский проигрыватель и так-то не очень хорошо поддерживается Qt, но тут я профан, поэтому даже и не знаю, что подсказать.
Опа… вот номер-то) создал эту страницу не локально а на серваке. и Она на мобилке открылась в WebView и все заработало… Т.е. вопрос все тот же … Я по ходу как-то не так передаю данные по локальному пути к этой хэтэмээль странице с плеером.))
Но то что все работает и на мобилке и локально это факт.
Но оставлять так это же не верно. Просто сколько запросов к этой странице станет)))
В общем как-то я не так передаю адрес. А как верно… всю голову изломал. Прост на компето работает с этим видом передачи, а на мобилке …
Ну теперь более понятна суть, конечно, но тогда здесь получается просто банальное обращение к серверу по определённому URL.
Если честно, после некоторого размышления после ответа, я даже не понял, почему это на ПК заработало.
А так да. Имеем страницу на сервере с встроенным сервером и просто открываем её в WebView. Получается топорно, но работает. И запросов будет конечно много к этой странице, хотя если кроме плеера на ней ничего нет, то и не страшно. Хотя я не знаю предполагаемого объёма трафика.
Может Вам посмотреть документацию по API YouTube? Как вариант, в QML должно поддерживаться потоковое вещание, тот же самый функционал Multimedia, дело останется только за реализацией отправки срабатывания кнопок проигрывания.
В общем проблема эта не уменя одного И как к ней подобраться не знаю
вот описание ее
http://stackoverflow.com/questions/29020930/qt-5-4-qtwebview-failing-to-load-local-html-from-qrc-on-android
но все что там предложени у меня не работает. Что делать не знаю…
Ну а вот и ответ… мать их…
Note: The WebView does not support loading content through the Qt Resource system.
Вау. Это я так понимаю в доках Qt написано где-то?
Могу тогда предложить следующий вариант.
Когда делаете APK для android, то можно воспользоваться директивой INSTALL, тогда можно будет указать, чтобы файл устанавливался в assets и дёргать его оттуда.
Один из подписчиков на YouTube так делал для базы данных SQLite, которая должна предустанавлвиваться с APK.
Угу. В них. В доках. Прям черным по белому.
А про assets это мысля тоже у некоторых проскакивала. Но вот у меня с синтаксисом не очень что-то.
Как прописать это в про файле если мой index.html положен в Other files, ну или я просто его рядом с main.qml кинул.?
PS а еще один товарисч додумался до того что в исходниках WebView свойство которое ну типа security = true он соответственно на false правил.
Если рядом с main.qml, то вот типо такого скорее всего будет:
Но это при условии, что index.html и .pro файл находятся в одном каталоге. Иначе там относительные пути надо будет описывать.
Какой главный принцип стартапа? – Сначала Тяп-Ляп, и если попёрло, то делаем нормально. Заодно и опыта будет больше через пол года. Там может быть просто напишите обработку потокового вещания с Ютуба без этой галиматьи с WebView.
Мне просто его отследить надо для организации подгрузки коментов с сервака, а то то что сейчас мне не очень нравится.. Просто сейчас я отслеживаю всякие там индексы у компонентов, но вот чую, что если знать название этого свойства, то все будет ок))
Действительно. Не стоило из-за этого новую тему создавать. Ибо, я тоже не знаю как оно называется )))))
Хотя понятно, что речь идёт об автоподгрузке, но как оно называется… хз.
Может имеется ввиду swipe? … хотя нет…
В onDragEnded обязательно нужно задать условие относительно которого порисходит отсчет на срабатывание.
В моем примере это refreshStart, который становится true если элемент листвью перешел определенную границу от края.
В общем это почти не отличается от того что я делал без onDragEnded. Также слушал когда что-то там чего-то перейдет по оси Y, но тут вернее т.к. Если не делать так, то каждое изменение по оси Y приводит к созданию запроса к БД и чтоб этого не было приходится писать костыль-ограничитель, а тут в onDragEnded это костыль можно сказать написан и официально узаконен))
Проще говоря onDragEnded – сигнал, который срабатывает когда заканчивается подтягивание контента. Есть еще onDragStarter и onDragChange, ну про что они думаю не стоит говорить))