废话不多说,咱直接进入正题!

创建 Electron 项目

前提条件

在使用Electron进行开发之前,需要安装 Node.js。

要检查 Node.js 是否正确安装,请在您的终端输入以下命令:

node -v
npm -v

脚手架创建

lectron 应用程序遵循与其他 Node.js 项目相同的结构。

首先创建一个文件夹并初始化 npm 包。

mkdir my-electron-app && cd my-electron-app
npm init

然后,将 electron 包安装到应用的开发依赖中。

npm install --save-dev electron

最后,您希望能够执行 Electron 如下所示,在您的 package.json 配置文件中的 scripts 字段下增加一条 start 命令:

{
"scripts": {
"start": "electron ."
}
}

start命令能让您在开发模式下打开您的应用

npm start

main.js 文件中的 createWindow 的函数中加入此代码可以打开控制台

mainWindow.webContents.openDevTools()

开发音视频

前提

引入 anyRTC 提供的 web RTC SDK

本地引入:官网下载

CDN 引入:

<script src="https://ardw.anyrtc.io/sdk/web/ArRTC@latest.js"></script>

npm 引入:

npm i ar-rtc-sdk -S

构建页面(简易版样式没写)

<div>
<p>AppID</P>
<input id="appid" type="text" placeholder="enter appid" required />
</div>
<div>
<p>Channel</P>
<input id="channel" type="text" placeholder="enter channel" required />
</div>
<div>
<p>Uid</P>
<input id="uid" type="text" placeholder="enter uid" required />
</div>
<!-- 用户视频容器 -->
<div id="remote-playerlist" class="row video-group"></div>

JS 构建语音通话(引用了JQ)

// ArRTC client
var client;
// 存放音视频
var localTracks = {
videoTrack: null,
audioTrack: null,
};
// 存放频道用户
var remoteUsers = {};
// ArRTC client options
var options = {
appid: null,
channel: null,
uid: null,
};
// 查看 SDK 版本
console.log(ArRTC.VERSION);
// 检测麦克风
const Cameras = await ArRTC.getCameras();
// 检测摄像头
const Microphones = await ArRTC.getMicrophones();
if (Cameras.length || Microphones.length) {
options.appid = $("#appid").val();
options.channel = $("#channel").val();
options.uid = $("#uid").val();
// 加入频道
join();
}
async function join() {
//创建本地视图
const localplayer = $(
`
<div class="col-6" id="local_video">
<p id="local-player-name" class="player-name"></p>
<div class="player-with-stats">
<div id="local-player" class="player"></div>
<div id="local-stats" class="stream-stats stats"></div>
</div>
</div>
`
);
$("#remote-playerlist").append(localplayer);
// create ArRTC client
client = await ArRTC.createClient({
mode: "rtc",
codec: "h264",
});
// 用户发布
client.on("user-published", handleUserPublished);
// 用户停止发布
client.on("user-unpublished", handleUserUnpublished);
[
options.uid,
localTracks.audioTrack,
localTracks.videoTrack,
] = await Promise.all([
// join the channel
client.join(
options.appid,
options.channel,
null,
options.uid || null
),
// create local tracks, using microphone and camera
ArRTC.createMicrophoneAudioTrack(),
ArRTC.createCameraVideoTrack(),
]);
// play local video track
localTracks.videoTrack.play("local-player");
$("#local-player-name").text(`localVideo(${options.uid})`);
// 发布本地视频
client.publish(Object.values(localTracks));
} // 远端用户发布
function handleUserPublished(user, mediaType) {
const id = user.uid;
remoteUsers[id] = user;
subscribe(user, mediaType);
}
// 远端用户停止发布
function handleUserUnpublished(user) {
const id = user.uid;
delete remoteUsers[id];
$(`#player-wrapper-${id}`).remove();
}
// 订阅远端用户发布的音视频
async function subscribe(user, mediaType) {
const uid = user.uid;
// subscribe to a remote user
await client.subscribe(user, mediaType);
if (mediaType === "video") {
const player = $(
`
<div id="player-wrapper-${uid}" class="col-6">
<p class="player-name">remoteUser(${uid})</p>
<div class="player-with-stats">
<div id="player-${uid}" class="player"></div>
<div class="track-stats stats"></div>
</div>
</div>
`
);
$("#remote-playerlist").append(player);
user.videoTrack.play(`player-${uid}`);
}
if (mediaType === "audio") {
user.audioTrack.play();
}
}

运行

npm start

打包

下载 electron-packager

npm install --save-dev electron-packager

package.json 文件的 scripts 加入

 "packager_all": "electron-packager ./ anyrtc --all --out ./dist --overwrite --electron-version=11.1.1 --ignore=node_modules --icon=./assets/images/favicon.icos"

执行

npm packager_all

最新文章

  1. 舍弃Nunit拥抱Xunit
  2. JS对象继承篇
  3. 离散信源的分类和数学模型&amp;&amp;离散无记忆信源的熵
  4. 安装oracle ebs 出现问题 atleast 55M of disk space
  5. 5天玩转C#并行和多线程编程 —— 第四天 Task进阶
  6. 安装numpy+mkl
  7. SQl server master
  8. struts过滤器和拦截器的区别
  9. Contoso 大学 - 7 – 处理并发
  10. 修改EditText的光标位置
  11. 几个国外FMX网站 good
  12. memcached学习——memcached的内存分配机制Slab Allocation、内存使用机制LRU、常用监控记录(四)
  13. Installing IIS 8.5 on Windows Server 2012 R2
  14. JAVA压缩图片 服务器端压缩图片 原创
  15. 这次真的忽略了一些ActiveMQ内心的娇艳
  16. TensorFlow读写数据
  17. &lt;记录&gt; HtmlHelper和 强类型页面
  18. 【译】第10节---数据注解-Key
  19. BZOJ 1063 道路设计(树形DP)
  20. linux安装mysql~~~mysql5.6.12

热门文章

  1. 精尽Spring Boot源码分析 - Jar 包的启动实现
  2. hdu5438 拓扑排序+DFS
  3. Linux指令手册 (一)
  4. SQL反模式读书笔记思维导图
  5. Linux下实现MySQL数据库定时备份
  6. Flyway:Spring Boot中使用Flyway来管理数据库版本
  7. vsftpd配置文件详解(转)
  8. WPF教程三:学习Data Binding把思想由事件驱动转变为数据驱动
  9. ESP32S2获取sht30温湿度
  10. iOS基于AVFoundation实现朗读文字