4.24 和 4.27 的官方案例,照着教程,直接就能跑通,4.26会出各种问题导致无法跑通。
查找了一些资料,最后也跑通了,记录一下4.26的过程。
需要看的两篇:
https://docs.unrealengine.com/4.27/en-US/SharingAndReleasing/PixelStreaming/PixelStreamingIntro/https://docs.unrealengine.com/4.27/en-US/SharingAndReleasing/PixelStreaming/PixelStreamingIntro/https://docs.unrealengine.com/4.27/en-US/Resources/Showcases/PixelStreamingShowcase/https://docs.unrealengine.com/4.27/en-US/Resources/Showcases/PixelStreamingShowcase/PixelStreamingDemo 在UE4 Market上面直接下载。
运行时,会报错,解决地址:
UE4.23/4.26像素流插件PixelStreaming使用Chrome访问时的Crash问题 - 知乎UE4.23/4.26像素流插件PixelStreaming使用Chrome浏览器访问时的Crash问题报错提示1:[...PixelStreaming/Private/Streaming.cpp] [Line:173] player 101 not found 报错提示2:信令服务器页面显示:player 102 con…https://zhuanlan.zhihu.com/p/357335311注意评论里信息,很关键:
?这样设置完,localhost能够显示界面,但是PixelDemo.htm依然不能征程,参考Player.htm,修改PixelDemo.htm,就可以了。
webRtcPlayer.js修改内容:
this.video = createWebRtcVideo();
this.cfg.offerExtmapAllowMixed = false;
onsignalingstatechange = function(state) {
console.info('signaling state change:', state)
};
// offer.sdp = offer.sdp.replace("useinbandfec=1", "useinbandfec=1;stereo=1;maxaveragebitrate=128000");
offer.sdp = offer.sdp.replace(/(a=extmap-allow-mixed)\r\n/gm, "");
pc.setLocalDescription(offer);
PixelDemo.htm 修改可行界面:
<!-- Copyright Epic Games, Inc. All Rights Reserved. -->
<!DOCTYPE HTML>
<html>
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<!-- Bootstrap CSS -->
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.2/css/bootstrap.min.css"
integrity="sha384-Smlep5jCw/wG7hdkwQ/Z5nLIefveQRIY9nfy6xoR1uRYBtpZgI6339F5dgvm/e9B" crossorigin="anonymous">
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.1.0/css/all.css"
integrity="sha384-lKuwvrZot6UHsBSfcMvOkWwlCMgc0TaWr+30HWe3a4ltaBwTZhyTEggF5tJv8tbt" crossorigin="anonymous">
<link type="text/css" rel="stylesheet" href="/player.css">
<script src="/socket.io/socket.io.js"></script>
<script type="text/javascript" src="https://webrtc.github.io/adapter/adapter-latest.js"></script>
<script type="text/javascript" src="/scripts/webRtcPlayer.js"></script>
<script type="text/javascript" src="/scripts/app.js"></script>
<script type="text/javascript" src="PixelDemo.js"></script>
<link type="text/css" rel="stylesheet" href="PixelDemo.css">
<meta name="apple-mobile-web-app-capable" content="yes" />
<!-- For iPhone X the following makes it use the entire screen space for the webpage https://webkit.org/blog/7929/designing-websites-for-iphone-x/ -->
<meta name='viewport' content='initial-scale=1, viewport-fit=cover'>
</head>
<body onload="load()">
<nav id="sidebar">
<ul id="sidebarlist" class="list-unstyled components">
<li>
<a href="#charSubmenu" data-toggle="collapse" aria-expanded="false"
class="dropdown-toggle">Characters</a>
<ul class="collapse list-unstyled" id="charSubmenu">
<li>
<a href="#" onclick="onConfigButton(0,0)"><img src="images/Aurora.png" width="150px" />
<h2><span>Aurora</span></h2>
</a>
</li>
<li>
<a href="#" onclick="onConfigButton(0,1)"><img src="images/Crunch.png" width="150px" />
<h2><span>Crunch</span></h2>
</a>
</li>
</ul>
</ul>
</nav>
<div class="wrapper">
<div id="content" class="container">
<div id="player"></div>
<div id="overlay" class="overlay">
<div>
<div id="qualityStatus" class="greyStatus"></div>
<div id="overlayButton"></div>
</div>
</div>
</div>
</div>
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"
integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo"
crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js"
integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49"
crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.2/js/bootstrap.min.js"
integrity="sha384-o+RDsa0aLu++PJvFqy8fFScvbHFLtbvScb8AjopnFD+iEQ7wo/CG0xlczd+2O/em"
crossorigin="anonymous"></script>
</body>
</html>
这样就能跑通了。
|