Android 使用腾讯sdk播放视频

Android 使用腾讯sdk播放视频

1.下载官方sdk
点击下载
在这里插入图片描述
在这里插入图片描述
拿到需要使用到的文件
在这里插入图片描述
在这里插入图片描述
将文件放在指定的位置
在这里插入图片描述

如何在build.gradle文件输入下面的代码导入jar包

implementation fileTree(dir: 'libs', include: ['*.jar'])

在这里插入图片描述
导包成功,该jar文件出现一个三角形
在这里插入图片描述
2.创建MyApplication.class文件
在这里插入图片描述
输入以下语法

package com.example.day_01;

import android.app.Application;
import android.util.Log;

import com.tencent.smtt.sdk.QbSdk;

public class MyApplication extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        QbSdk.PreInitCallback pcb=new QbSdk.PreInitCallback() {
            @Override
            public void onCoreInitFinished() {

            }

            @Override
            public void onViewInitFinished(boolean b) {
                //x5內核初始化完成的回调,为true表示x5内核加载成功,否则表示x5内核加载失败,会自动切换到系统内核。
                Log.e("myApplication", " x5内核加载成功?" + b);
            }
        };
        //x5内核预加载,异步初始化x5 webview所需环境
        QbSdk.initX5Environment(getApplicationContext(), pcb);
    }
}

完成之后,在AndroidManifest.xml进行声明
在这里插入图片描述
3.添加权限
在这里插入图片描述

    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.READ_SETTINGS" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <!-- 硬件加速对X5视频播放有利,建议开启 -->
    <uses-permission android:name="android.permission.GET_TASKS" />

4.清单文件AndroidManifest.xml中配置SDK中的视频播放Activity
在这里插入图片描述

<activity
            android:name="com.tencent.smtt.sdk.VideoActivity"
            android:alwaysRetainTaskState="true"
            android:configChanges="orientation|screenSize|keyboardHidden"
            android:exported="false"
            android:launchMode="singleTask">
            <intent-filter>
                <action android:name="com.tencent.smtt.tbs.video.PLAY" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>

注:如果遇到模拟机或者真机测试无网络,请在AndroidManifest.xml文件下输入下面代码

android:usesCleartextTraffic="true"

在这里插入图片描述
横屏播放视频,请在AndroidManifest.xml文件下输入下面代码

android:configChanges="orientation|screenSize|keyboardHidden"

在这里插入图片描述
5.实现功能
(1)找到下载的sdk包下的java文件
在这里插入图片描述
创建tools目录,复制粘贴到该目录下
在这里插入图片描述
在这里插入图片描述

(2)配置activity_main.xml文件
在这里插入图片描述
报错忽略

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.day_01.MainActivity">

    <com.example.day_01.tools.X5WebView
        android:id="@+id/x5_webview"
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:scrollbars="none">
    </com.example.day_01.tools.X5WebView>

</androidx.constraintlayout.widget.ConstraintLayout>

(3)在MainActivity.java文件输入下面代码

package com.example.day_01;

import androidx.appcompat.app.AppCompatActivity;

import android.graphics.PixelFormat;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

import com.example.day_01.tools.X5WebView;
import com.example.xch.tbsvideoplay.R;
import com.tencent.smtt.sdk.WebChromeClient;

public class MainActivity extends AppCompatActivity {
    private X5WebView x5webView;
    private String videoUrl="https://vodkgeyttp8.vod.126.net/cloudmusic/ec3e/core/76fd/4345f88037c5520bb00d84130796220f.mp4?wsSecret=9398df69d20d5da20ce02e9237b2f350&wsTime=1619354212";//视频地址(运行时请确认此链接是否还可用,如不可用换一个就行)
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        x5webView = findViewById(R.id.x5_webview);
        startPlay(videoUrl);
    }
    /**
     * 使用自定义webview播放视频
     * @param vedioUrl 视频地址
     */
    private void startPlay(String vedioUrl) {
        x5webView.loadUrl(vedioUrl);
        getWindow().setFormat(PixelFormat.TRANSLUCENT);
        x5webView.getView().setOverScrollMode(View.OVER_SCROLL_ALWAYS);
        x5webView.setWebChromeClient(new WebChromeClient());
    }
}

(4)运行测试
在这里插入图片描述
在这里插入图片描述
6.源代码

https://download.csdn.net/download/Scxioi0/17931319

作者wanliyang1990,源码wlmedia,1、UsageGradle: implementation 'ywl.ywl5320:wlmedia:1.0.0-beta17'2、实例图片播放视频播放 byte[](如:标准的 h264 h265 等)播放音乐竖屏播放(自动保持宽高比)横屏播放(自动保持宽高比)3、调用方式配置 NDK 编译平台:defaultConfig {     ...     ndk {         abiFilter("arm64-v8a")         abiFilter("armeabi-v7a")         abiFilter("x86")         abiFilter("x86_64")     }     ... }基本权限接入代码(SDK API level:28)// WlSurfaceView 一般播放使用// WlTextureView 需要做透明、移动、旋转等使用WlMedia wlMedia = new WlMedia();// 可支持多实例播放(主要对于音频,视频实际验证效果不佳) wlMedia.setPlayModel(WlPlayModel.PLAYMODEL_AUDIO_VIDEO);//声音视频都播放 wlMedia.setCodecType(WlCodecType.CODEC_MEDIACODEC);//优先使用硬解码 wlMedia.setMute(WlMute.MUTE_CENTER);//立体声 wlMedia.setVolume(80);//80%音量 wlMedia.setPlayPitch(1.0f);//正常速度 wlMedia.setPlaySpeed(1.0f);//正常音调 wlMedia.setRtspTimeOut(30);//网络流超时时间 wlMedia.setShowPcmData(true);//回调返回音频 pcm 数据 wlMedia.setSampleRate(WlSampleRate.RATE_44100);//设置音频采样率为指定值(返回的 PCM 就是这个采样率) wlSurfaceView.setWlMedia(wlMedia);//给视频 surface 设置播放器 //异步准备完成后开始播放 wlMedia.setOnPreparedListener(new WlOnPreparedListener() {         @Override         public void onPrepared() {         // wlMedia.setVideoScale(WlScaleType.SCALE_16_9);//设置 16:9 的视频比例             wlMedia.start();//开始播放             double duration = wlMedia.getDuration();//获取时长         }     }); //设置 url 源 wlMedia.setSource("/storage/sdcard1/精灵宝可梦:就决定是你了.720p.国日粤三语.BD 中字[最新电影 www.66ys.tv].mp4"); wlMedia.prepared();//异步准备
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值