-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add ios demo & readme Update README.md Update README.md Update README.md Update README.md modify android demo Update README.md Update README.md Update README.md Update demo Add demo qrcode Update README.md 丰富超分方案,设为readme 替换播放器场景的素材; 更新链接; Feature: Demo dump sr video fix: 1. The rotation direction is incorrect when some videos are played. 2. The file name is incorrect when exporting the video. Demo fix the issue of the dump video duration being too long. Demo fix the issue of the pts of frames might be 0. 优化体验demo的二维码显示大小 Android demo fix crash on dumping some resolutions of video. Update demo Update docs Update README.md Update README.md Update README.md Update demo
- Loading branch information
Showing
118 changed files
with
3,709 additions
and
1,076 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,98 +1,45 @@ | ||
# **TSRSDK接入指南** | ||
## 1. **SDK授权申请** | ||
请联系您的腾讯云商务开通服务。您需要提供将要集成SDK的App的这些信息:腾讯云账号APPID、App签名证书信息(签名证书的序列号、发布者、所有者)、App包名。 | ||
# 超分辩率 | ||
## 播放器场景 | ||
终端播放器集成超分辨率能力,提高播放清晰度。 | ||
|
||
APPID可以在您的腾讯云【账号中心】->【账号信息】->【基本信息】中查看。 | ||
App签名证书信息可以使用keytool命令查看,例如 | ||
```keytool -list -v -keystore test.keystore``` | ||
<img src=./docs/scenario_play.png/> | ||
|
||
data:image/s3,"s3://crabby-images/64d07/64d07842824cd760f3ae742529f691bed31ad015" alt="cert.png" | ||
540P图像双线性放大1.5倍(test540\_1.5\_bilerp)和超分放大1.5倍(test540\_1.5\_tsr)的[效果对比](https://cg-sdk-1258344699.cos.ap-nanjing.myqcloud.com/personal/handleychen/icat-test540.html) | ||
## 监控场景 | ||
受益于播放端的超分功能,可以降低视频监控上行的带宽和存储。 | ||
|
||
提供的信息 | ||
|信息|值| | ||
| :- | :- | | ||
|APPID|12345678| | ||
|包名|com.tencent.mps.srplayer| | ||
|序列号|17ccecf2| | ||
|所有者|test| | ||
|发布者|test| | ||
<img src=./docs/scenario-monitor.png width=60% /> | ||
|
||
离线授权方案分为授权申请和授权验证两个过程,其中授权申请在授权有效期内,只会进行一次。授权服务开通后,我们会给您提供离线的license,用于在TSRSDK初始化时进行鉴权。授权服务具有有效期限,当授权过期失效后需要重新获取授权。 | ||
|
||
## 2. **SDK接入指南** | ||
### **2.1 程序流程** | ||
data:image/s3,"s3://crabby-images/bffa3/bffa39d9691a1730e0ef52ccb4d4dc0aba16a8f1" alt="tsr-work-flow.png" | ||
## 性能 | ||
测试手机Google Pixel 6(芯片Tensor, GPU Mali-G78,性能约等于骁龙870)。720P图像2倍超分耗时约0.5ms,1080P图像2倍超分耗时约0.9ms。对播放器渲染帧率几乎无影响。 | ||
更多性能数据如下 | ||
|原始分辨率|超分后分辨率|耗时| | ||
| :- | :- | :- | | ||
|352x640|704x1280|0.2ms| | ||
|544x960|1088x1920|0.3ms| | ||
|720x1280|1440x2560|0.5ms| | ||
|1080x2400|2160x4800|1ms| | ||
|
||
#### **2.1.1 TsrSdk** | ||
[TsrSdk](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrSdk.html)包括init和release两个方法。init方法用于初始化SDK,release方法用于释放资源。 | ||
## 兼容性 | ||
Android平台:Android5.0以上(API 21,OpenGL ES 3.1),兼容目前Android市场上99.6%的手机。 | ||
|
||
1. 离线鉴权初始化[TsrSdk](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrSdk.html#init(long,java.lang.String,com.tencent.mps.tsr.api.TsrLogger)),您需要传入**APPID、license路径**用于离线鉴权,除此之外,还需要传入一个 [TsrLogger](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrLogger.html),用于获取SDK的日志。[init](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrSdk.html#init(long,java.lang.String,com.tencent.mps.tsr.api.TsrLogger))会有返回值[SdkLicenseStatus](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrSdk.SdkLicenseStatus.html) ,表示license校验的结果。下面是示例代码: | ||
``` | ||
String licensePath = "----path to you sdk license.----"; | ||
TsrSdk tsrSdk = TsrSdk.getInstance(); | ||
SdkLicenseStatus status = tsrSdk.init(appId, licensePath, logger); | ||
if (status == SdkLicenseStatus.AVAILABLE) { | ||
// Perform super-resolution rendering using TsrPass class. | ||
} else { | ||
// Do something when the verification of sdk's license failed. | ||
} | ||
``` | ||
iOS平台:适用于 iPhone 5s及更高版本的设备,最低系统版本为iOS 12。 | ||
|
||
## 包大小 | ||
Android AAR约0.6M(含arm64-v8a和armeabi-v7a)。iOS Framework约1.6M。 | ||
|
||
2. 当您已经不需要使用TsrSdk时,需要调用TsrSdk的release方法,释放资源。<font color="red">**注意:在调用TsrSdk的release方法前,确保所有TsrPass已经被release,否则会有意想不到的问题。**</font> | ||
``` | ||
// If you have created TsrPass, you should release it before release TsrSdk. | ||
tsrPass.release(); | ||
// Release resources when the TsrSdk object is no longer needed. | ||
tsrSdk.release(); | ||
``` | ||
#### **2.1.2 TsrPass** | ||
[TsrPass](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrPass.html)是用于进行超分辨率渲染的类,它包括了init、render和release方法。在使用TsrPass前,您需要调用init方法进行初始化。在使用结束后,您需要调用release方法释放资源。 | ||
## 优势 | ||
适应手机终端算力、能耗、机型兼容、包体增量的限制,以极高性能和极低功耗实现终端上最佳的超分辨率质量。 | ||
|
||
以下是代码示例: | ||
``` | ||
// Create a TsrPass object using the constructor. | ||
TsrPass tsrPass = new TsrPass(); | ||
## 体验Demo | ||
用手机系统浏览器打开,下载安装 | ||
|Android| | ||
| :- | | ||
| <img src=./docs/android-demo-qrcode.png width=30% />| | ||
|
||
// The code below must be executed in glThread. | ||
//----------------------GL Thread---------------------// | ||
// Init TsrPass | ||
tsrPass.init(inputWidth, inputHeight, srRatio); | ||
// If the type of inputTexture is TextureOES, you must transform it to Texture2D. | ||
int outputTextureId = tsrPass.render(inputTextureId); | ||
//----------------------GL Thread---------------------// | ||
// Release resources when the TsrPass object is no longer needed. | ||
tsrPass.release(); | ||
``` | ||
|
||
#### **2.1.3 TsrLogger** | ||
[TsrLogger](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/TsrLogger.html)用于接收SDK内部的日志,请将这些日志写到文件,以便定位外网问题。 | ||
### **2.2 API文档** | ||
您可以点击连接查看TSRSDK的API文档,内含接口注释与调用示例。 | ||
|
||
[TSRSDK API文档](https://tencentyun.github.io/TSR/com/tencent/mps/tsr/api/package-summary.html) | ||
### **2.3 体验Demo** | ||
#### **2.3.1 安装包** | ||
请联系您的腾讯云商务获取。 | ||
#### **2.3.2 源码** | ||
我们开放了体验Demo的工程源码,供您接入参考。 | ||
|
||
为了编译运行,您需要先联系腾讯云商务获取SDK和授权,再配置到Demo工程中。步骤如下: | ||
|
||
1. 将SDK放在工程的./SRPlayer/app/libs文件夹下。 | ||
|
||
2. 在MainActivity.java下配置初始化参数,离线校验初始化需要APPID与licensePath。如果您只是想快速的运行demo,您可以把license直接放入./SRPlayer/app/src/main/assets文件夹内,demo会去读取assets文件夹中的文件拷贝到sdcard中,用于初始化TsrSdk。 | ||
|
||
data:image/s3,"s3://crabby-images/a441c/a441c7fe23ee37eca962c8626f2be1854bc15b56" alt="verification-params.png" | ||
|
||
|
||
3. 对APK进行签名 | ||
- 在Android Studio中,找到【File】-> 【Project Structure】 -> 【Modules】-> 【Signing Configs】中配置您的签名证书。 | ||
- 或者您可以在【Build】-> 【Generate Signed Bundle / APK】使用证书生成签名的APK | ||
- 无论您使用哪种方式,<font color="red">**请确保配置的签名证书与提供给我们的信息一致。**</font> | ||
|
||
4. 运行demo | ||
|
||
## 接入SDK | ||
<img src=./docs/integrate1.png width=40% /> | ||
|
||
参考[接入指南](接入指南.md) |
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.