android - 解决了 !如何在我的 nativescript 应用程序中实现视频播放?
问题描述
我使用 nativescript-videorecorder 录制视频,并从 nativescript-videoplayer 插件保存的文件中播放。在 iOS 中它像梦一样工作,但在 android 中,我最多只能实现黑屏(只有在我使用 exoplayer 时才会有声音)。我有最新版本的 nativescript 和插件。我的项目使用 webpack。在网上找到的示例,链接到提到的插件,也不起作用。任何人都可以解决这个问题吗?
function takeVideo()
{ var options = { saveToGallery: false, 持续时间: 10, size: 300, hd: false, 解释: '' }
var permreq = [];
if(isAndroid) permreq = [android.Manifest.permission.RECORD_AUDIO, android.Manifest.permission.CAMERA];
permissions.requestPermission(permreq, "Uw toestemming is nodig om video-opnamen te kunnen maken.")
.then(function ()
{
permissions.requestPermission([android.Manifest.permission.READ_EXTERNAL_STORAGE,
android.Manifest.permission.WRITE_EXTERNAL_STORAGE], 'We hebben toegang tot het bestandssysteem nodig om uw bestand op te slaan').then(function () {
var videorecorder = new vr.VideoRecorder(options);
videorecorder.record(options).then(data => {
// get file from data here
}
}).catch((err) => {
console.log(err);
});
});
});
} 出口.takeVideo = takeVideo;
ios中的播放效果很好。对于 android,我无法让我保存的 mp4 文件正常工作,而且下面提到的 url 也不会在显示器上呈现图片。
<StackLayout id = "zoomvideo" className="collapse" height = "100%" verticalAlignment="top">
<VideoPlayer:Video height="100%" row="1"
loaded="videoplayerLoaded"
src="https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"
finished="videoFinished" controls="true"
autoplay="false" id = "vidplayer" fill = "true" /> </StackLayout>
解决方案
我解决了这个问题......在Android清单中, android:hardwareAccelerated="false" 导致了这个问题。通过将其设置为 true 来解决这个问题会带来一个新的(影响较小的)问题。我现在在一些背景透明的元素中有阴影......这是因为将 hardwareAccelerated 设置为 true,我使用的 z-index 创建了不需要的高度。我从来没有注意到这一点,因为海拔不适用于 hardwareAccelerated=false....
推荐阅读
- python - 将一个值为 `val` 的节点追加到列表 python3 的末尾
- clojure - 子线程中的 printf 不输出任何内容
- php - SagePay / Chrome 80 / 3D Secure / Samesite 和丢失的会话 ID
- c# - C# Easyhook 奇怪的行为
- excel - Excel VBA:用户表单代码替换行内容而不是添加新内容
- java - 改造 2:从响应数组中提取值
- amazon-web-services - 无法使用 travis ci 在 elasticbeanstalk 中部署 docker 应用程序
- azure-functions - 部署后重新启用旧的 azure 功能
- php - 如何在elementor中添加自定义小部件ICON
- mysql - 在 mysql 表上运行完整搜索