1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/sakaue-QSVideoPayer

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Это зеркальный репозиторий, синхронизируется ежедневно с исходного репозитория.
Клонировать/Скачать
Внести вклад в разработку кода
Синхронизировать код
Отмена
Подсказка: Поскольку Git не поддерживает пустые директории, создание директории приведёт к созданию пустого файла .keep.
Loading...
README.md
  • QSVideoView интерфейс улучшен, функции обогащены:
    • Поддержка настройки соотношения сторон видео.
    • Поддержка двух типов всплывающих окон.
    • Поддержка расширения декодера.
    • Интеллектуальное переключение полноэкранного режима.
    • Поддержка локального кэширования.
    • Поддержка изменения скорости и отключения звука и т. д.
  • Архитектура разработана хорошо, модульный расширяемый дизайн, модуль декодирования в настоящее время предоставляет декодеры AndroidMedia (встроенный в систему), ijkMedia (на основе ffmepg) + ijkExoMedia (на основе exo), ExoMedia (2.0.4).
  • Можно выбрать SurfaceView и TextureView.
  • Поддерживаются локальные видео, онлайн-видео, прямые трансляции m3u8 и т.д.
  • Предоставляется готовый плеер DemoQSVideoView с поддержкой жестов и разрешения.
  • Сверхбыстрое создание: достаточно 100 строк кода Java, чтобы создать свой собственный плеер! Предоставляется вспомогательный класс QSVideoViewHelp, который обеспечивает логику общих элементов управления и поддержку жестов, позволяет быстро настроить пользовательский интерфейс и создать собственный плеер без написания логики воспроизведения.
  • Предлагается фреймворк для автоматического уничтожения списка воспроизведения видео.
  • Интеграция системы титров с помощью одной строки кода.

Preview

Использование

Автоматическая интеграция Gradle

allprojects {
    repositories {
        maven {
            url "https://jitpack.io"
        }
    }
}

dependencies {
    implementation 'com.gitee.sakaue:QSVideoPayer:2.2.9'

    //Если нужна поддержка других архитектур декодеров ijk, по умолчанию только v7
    //so не существует ошибки, можно настроить ndk{abiFilters 'armeabi-v7a'} или импортировать следующий пакет
    //implementation 'tv.danmaku.ijk.media:ijkplayer-armv5:0.8.8'
    //implementation 'tv.danmaku.ijk.media:ijkplayer-arm64:0.8.8'
    //implementation 'tv.danmaku.ijk.media:ijkplayer-x86:0.8.8'
    //implementation 'tv.danmaku.ijk.media:ijkplayer-x86_64:0.8.8'
}

Ручная интеграция

Скачайте проект, добавьте папку qsvideoplayer в качестве зависимости вашего проекта. Вы можете выбрать нужный декодер в соответствии с вашими потребностями: по умолчанию обычно достаточно простого воспроизведения видео AndroidMedia (минимальный объём, отсутствие зависимостей). Если вам нужно больше, вы можете выбрать AndroidMedia+ (ijkMedia+ijkExoMedia) (пакет 2 МБ только для v7a). В настоящее время протестированный декодер ijkMedia имеет лучшую совместимость, AndroidMedia иногда прерывает воспроизведение некоторых видеофайлов, у exo нет явных недостатков.

Если вы хотите упростить удаление декодера ijk: в build.gradle закомментируйте все зависимости, удалите три класса IjkBaseMedia IjkExoMedia IjkMedia из пакета media, и всё готово. Титры и декодер exo находятся в демоверсии, их необходимо скачать отдельно и интегрировать.

API интерфейс QSVideoView

    void setUp(String url, Object... objects);//设置视频地址

    void play();//播放/初始化(完成自动播放)

    void prePlay();//初始化(完成不会播放)

    void pause();//暂停

    void seekTo(int duration);//进度调节

    void setPlayListener(PlayListener playListener);//播放监听 参数含义参照IVideoPlayer

    void addPlayListener(PlayListener playListener);//多播放监听

    void removePlayListener(PlayListener playListener);//移除播放监听

    void setAspectRatio(int aspectRatio);//设置视频比例 参数见IRenderView

    void setDecodeMedia(Class<? extends BaseMedia> claxx);//设置解码模块
    
    void openCache();//打开缓存

    boolean onBackPressed();//返回键退出全屏

    boolean isPlaying();//是否播放中

    void enterWindowFullscreen();//全屏

    void quitWindowFullscreen();//退出全屏

    boolean enterWindowFloat(FloatParams floatParams);//浮窗 false没权限

    void quitWindowFloat();//退出浮窗

    boolean setMute(boolean isMute);//是否静音 false不支持

    boolean setSpeed(float rate);//设置播放倍速,false不支持

    void release();//销毁

    Bitmap getCurrentFrame();//截图

    int getPosition();//获取播放进度

    int getDuration();//获取视频时长

    int getVideoWidth();//获取视频宽

    int getVideoHeight();//获取视频长

    int getCurrentMode();//获得播放器当前的模式(全屏,普通,浮窗)

    int getCurrentState();//获得播放器当前的状态(播放,暂停,完成...)

Использование демо

JAVA

    //DemoQSVideoView的ui用的jc播放器
    DemoQSVideoView qsVideoView = (DemoQSVideoView) findViewById(R.id.xxx);

    qsVideoView.setUp(url, "这是一一一一一一一一一个标题");

    //设置多个清晰度和ijk配置
    //List<IjkMedia.Option> list = new ArrayList<>();
    //list.add(new IjkMedia.Option(IjkMediaPlayer.OPT_CATEGORY_PLAYER, "soundtouch", 1));
    //demoVideoView.setUp(
    //                QSVideo.Build(url).title("这是标清标题").definition("标清").resolution("标清 720P").build(),
    //                QSVideo.Build(url).title("这是高清标题").definition("高清").resolution("高清 1080P").option(list).build());

    qsVideoView.getCoverImageView().setImageResource(R.mipmap.cover);//封面

    //设置监听
    qsVideoView.setPlayListener(new PlayListener() {
            @Override
            public void onStatus(int status) {//播放器的ui状态
                if (status == IVideoPlayer.STATE_AUTO_COMPLETE) ```
qsVideoView.quitWindowFullscreen();//播放完成退出全屏
            }

            @Override//全屏/普通/浮窗...
            public void onMode(int mode) {

            }

            @Override//播放事件 初始化完成/缓冲/出错/点击事件...
            public void onEvent(int what, Integer... extra) {

            }
        });
    //进入全屏的模式 0横屏 1竖屏 2传感器自动横竖屏 3根据视频比例自动确定横竖屏      -1什么都不做
    qsVideoView.enterFullMode=3;
    qsVideoView.play();

返回键退出全屏

    @Override
    public void onBackPressed() {
        if (qsVideoView.onBackPressed())
            return;
        super.onBackPressed();
    }

XML

        <org.song.videoplayer.DemoQSVideoView
                android:id="@+id/xxx"
                android:layout_width="match_parent"
                android:layout_height="400dp" />

AndroidManifest

        <activity
            android:name=".VideoActivity"
            android:configChanges="orientation|keyboardHidden|screenSize">
        </activity>

悬浮窗

    FloatParams floatParams = new FloatParams();
    floatParams.x = 0;//浮窗中心坐标x
    floatParams.y = 0;//浮窗中心坐标y
    floatParams.w = 540;//宽
    floatParams.h = 270;//高
    floatParams.round = 30;//浮窗圆角 需SDK_INT >= 21
    floatParams.fade = 0.8f;//透明度 需SDK_INT >= 11
    floatParams.canMove = true;//是否可以拖动
    floatParams.canCross = false;//是否可以越屏幕边界
    floatParams.systemFloat = true;TRUE系统浮窗需要权限 FALSE界面内浮窗

    if (!qsVideoView.enterWindowFloat(floatParams)) {
        Toast.makeText(this,"没有浮窗权限",Toast.LENGTH_LONG).show();
        Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,
              Uri.parse("package:" + getPackageName()));
        startActivityForResult(intent, 0);
        }
    }

生命周期控制

实现后台暂停播放,超过15秒销毁,回来还原播放状态,体验好

    private boolean playFlag;//记录退出时播放状态 回来的时候继续播放
    private int position;//记录销毁时的进度 回来继续该进度播放
    private Handler handler = new Handler();

    @Override
    public void onResume() {
        super.onResume();
        if (playFlag)
            demoVideoView.play();
        handler.removeCallbacks(runnable);
        if (position > 0) {
            demoVideoView.seekTo(position);
            position = 0;
        }
    }

    @Override
    public void onPause() {
        super.onPause();
        if (demoVideoView.isSystemFloatMode())
            return;
        //暂停
        playFlag = demoVideoView.isPlaying();
        demoVideoView.pause();
    }


    @Override
    public void onStop() {
        super.onStop();
        if (demoVideoView.isSystemFloatMode())
            return;
        //进入后台不马上销毁,延时15秒
        handler.postDelayed(runnable, 1000 * 15);
    }

    @Override
    public void onDestroy() {
        super.onDestroy();//销毁
        if (demoVideoView.isSystemFloatMode())
            demoVideoView.quitWindowFloat();
        demoVideoView.release();
        handler.removeCallbacks(runnable);
    }

    private Runnable runnable = new Runnable() {
        @Override
        public void run() {
            if (demoVideoView.getCurrentState() != IVideoPlayer.STATE_AUTO_COMPLETE)
                position = demoVideoView.getPosition();
            demoVideoView.release();
        }
    };

DIY播放器:

0.read source code.

1.可直接修改DemoQSVideoView改造自己的播放器

2.继承QSVideoViewHelp参考DemoQSVideoView,源码均有注释,不用写一行播放逻辑
(1) 子类提供layout布局,布局里需要help类实现逻辑的控件,设置id为以下特定id即可

   <!--ImageView播放按钮1 2-->
   <item name="help_start" type="id" />
   <item name="help_start2" type="id" />
   <!--TextView播放时间  视频时长-->
   <item name="help_total" type="id" />
   <item name="help_current" type="id" />
   <!--ProgressBar进度条  SeekBar拖动条-->
   <item name="help_progress" type="id" />
   <item name="help_seekbar" type="id" />
   <!--ImageView全屏按钮  View返回按钮-->
   <item name="help_fullscreen" type="id" />
   <item name="help_back" type="id" />

   //如播放按钮定义,注意: @id 没有加号,这样定义父类会自动完成该按钮逻辑
   <ImageView
           android:id="@id/help_start"
           android:layout_width="60dp"
           android:layout_height="60dp"
           android:layout_centerInParent="true"/>
``` В Java-коде можно настроить пользовательский интерфейс для каждого состояния, чтобы создать свой собственный плеер. Для этого нужно обратиться к DemoQSVideoView.

3. Используйте QSVideoView напрямую, создайте пользовательский интерфейс и логику управления (наследование: DemoQSVideoView → QSVideoViewHelp → QSVideoView).

## Log
### v2.2.9(2021-09-12)
* Проблема с виртуальными клавишами в полноэкранном режиме.
* Проблемы с URI.
* Другие оптимизации.
### v2.2.8(2019-04-12)
* Выбор чёткости.
* Оптимизация.
### v2.2.7(2019-01-05)
* Ускоренное воспроизведение.
* Оптимизация.
### v2.2.5(2018-10-24)
* Поддержка кэширования видео.
### v2.2.4(2018-09-01)
* Эффект отскока при выходе окна за пределы экрана.
* Оптимизация.
### v2.2.3(2018-05-12)
* +Danmaku (интеграция титров одним кодом).
* +getCurrentFrame (добавление функции скриншота >= 4.0).
* +support systemfloat goback (система плавающих окон может вернуться назад).
* +perfect listenner (улучшенный прослушиватель событий).
### v2.2.2(2018-02-13)
* Можно получить параметры плавающего окна после перемещения.
* Проблема callback onInfo (804, -1004) в версии 8.0.
* Демонстрация Immersion (погружение).
### v2.2.1(2018-01-30)
* Добавление плавающего окна в активности (плавающее окно в интерфейсе, не требует разрешений).
* Добавление слушателя событий (seekbar).
### v2.2.0(2018-01-28)
* Добавление функции плавающего окна.
### v2.1.1(2018-01-08)
* -Добавить функцию отключения звука.
* -Добавить режим полного экрана (автоматическое определение ориентации экрана).
* -Поддержка воспроизведения по URI.
* -Скрыть панель навигации в полноэкранном режиме.
* -Исправление ошибок.

## Other
* Если у вас есть вопросы, пожалуйста, добавьте их в [issues](https://gitee.com/sakaue/QSVideoPayer/issues).
* Если проект вам полезен, вы можете поставить ему «звезду».
* Логотип @[mirzazulfan](https://github.com/mirzazulfan).

[logopng]: https://gitee.com/sakaue/QSVideoPayer/raw/master/source/logo.png

[qrpng]: https://gitee.com/sakaue/QSVideoPayer/raw/master/source/video_qrcode.png

[relesesvg]: https://img.shields.io/github/release/tohodog/QSVideoPlayer.svg
[relesezip]: https://codeload.github.com/tohodog/QSVideoPlayer/zip/2.2.7

[apkurlsvg]: https://img.shields.io/badge/download-demo.apk-brightgreen.svg?style=flat
[apkurl]: https://gitee.com/sakaue/QSVideoPayer/raw/master/source/qsvideoplayer.apk

[apisvg]: https://img.shields.io/badge/API-9+-brightgreen.svg
[api]: https://android-arsenal.com/api?level=9

[licensesvg]: https://img.shields.io/badge/License-Apache--2.0-red.svg
[license]: https://gitee.com/sakaue/QSVideoPayer/raw/master/LICENSE

[starsvg]: https://img.shields.io/github/stars/tohodog/QSVideoPlayer.svg?style=social&label=Stars
[star]: https://gitee.com/sakaue/QSVideoPayer

Комментарии ( 0 )

Вы можете оставить комментарий после Вход в систему

Введение

Описание недоступно Развернуть Свернуть
Apache-2.0
Отмена

Обновления (1)

все

Участники

все

Недавние действия

Загрузить больше
Больше нет результатов для загрузки
1
https://gitlife.ru/oschina-mirror/sakaue-QSVideoPayer.git
git@gitlife.ru:oschina-mirror/sakaue-QSVideoPayer.git
oschina-mirror
sakaue-QSVideoPayer
sakaue-QSVideoPayer
master