Compare commits
7 Commits
e05cda7d21
...
ef2eb499ab
| Author | SHA1 | Date |
|---|---|---|
|
|
ef2eb499ab | |
|
|
b86c4230bb | |
|
|
c9362fc14d | |
|
|
1b7480cadc | |
|
|
606715ced6 | |
|
|
e2615f846f | |
|
|
fc50a28504 |
59
main.js
59
main.js
|
|
@ -12,6 +12,7 @@ const {
|
||||||
} = require('electron');
|
} = require('electron');
|
||||||
const path = require('node:path')
|
const path = require('node:path')
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
|
const https = require('https');
|
||||||
const { autoUpdater, CancellationToken } = require('electron-updater');
|
const { autoUpdater, CancellationToken } = require('electron-updater');
|
||||||
const cancellationToken = new CancellationToken()
|
const cancellationToken = new CancellationToken()
|
||||||
app.allowRendererProcessReuse = false;
|
app.allowRendererProcessReuse = false;
|
||||||
|
|
@ -271,6 +272,25 @@ app.on('ready', () => {
|
||||||
const y = Math.round((display.workArea.height - mainWindow.getSize()[1]) / 2);
|
const y = Math.round((display.workArea.height - mainWindow.getSize()[1]) / 2);
|
||||||
mainWindow.setPosition(x, y);
|
mainWindow.setPosition(x, y);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// 监听渲染进程请求应用数据目录
|
||||||
|
ipcMain.handle('get-user-data-path', () => {
|
||||||
|
return app.getPath('userData');
|
||||||
|
});
|
||||||
|
// 用户数据目录路径
|
||||||
|
const userDataPath = app.getPath('userData'); // 全局变量
|
||||||
|
console.log('User Data Path:', userDataPath);
|
||||||
|
// 检查并下载 ffmpeg
|
||||||
|
checkAndDownloadFFmpeg(userDataPath)
|
||||||
|
.then(() => {
|
||||||
|
console.log('FFmpeg is ready for use.');
|
||||||
|
// 在这里执行任何依赖于 ffmpeg 的操作
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
console.error('Failed to ensure ffmpeg is available:', error);
|
||||||
|
app.quit();
|
||||||
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// 检测更新,在你想要检查更新的时候执行,renderer事件触发后的操作自行编写
|
// 检测更新,在你想要检查更新的时候执行,renderer事件触发后的操作自行编写
|
||||||
|
|
@ -339,3 +359,42 @@ function cancleDownloadUpdate() {
|
||||||
function quitAndInstall() {
|
function quitAndInstall() {
|
||||||
autoUpdater.quitAndInstall();
|
autoUpdater.quitAndInstall();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// 下载文件
|
||||||
|
function downloadFile(url, dest) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const file = fs.createWriteStream(dest);
|
||||||
|
https.get(url, function (response) {
|
||||||
|
response.pipe(file);
|
||||||
|
file.on('finish', function () {
|
||||||
|
file.close(resolve);
|
||||||
|
});
|
||||||
|
}).on('error', function (err) {
|
||||||
|
fs.unlink(dest, () => reject(err));
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检查并下载ffmpeg
|
||||||
|
function checkAndDownloadFFmpeg(appPath) {
|
||||||
|
const ffmpegPath = path.join(appPath, 'ffmpeg.exe');
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
if (!fs.existsSync(ffmpegPath)) {
|
||||||
|
console.log(`ffmpeg.exe not found at ${ffmpegPath}, downloading...`);
|
||||||
|
downloadFile('https://meeting-api.23544.com/meeting/update/ffmpeg.exe', ffmpegPath)
|
||||||
|
.then(() => {
|
||||||
|
console.log('ffmpeg.exe downloaded successfully.');
|
||||||
|
resolve();
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
console.error('Error downloading ffmpeg.exe:', error);
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.log(`ffmpeg.exe found at ${ffmpegPath}.`);
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"name": "WGShare.Metting",
|
"name": "WGShare.Metting",
|
||||||
"private": true,
|
"private": true,
|
||||||
"version": "0.1.14",
|
"version": "0.3.1",
|
||||||
"main": "main.js",
|
"main": "main.js",
|
||||||
"authors": "yj",
|
"authors": "yj",
|
||||||
"description": "智汇享",
|
"description": "智汇享",
|
||||||
|
|
|
||||||
|
|
@ -21,8 +21,10 @@ import StupWizard from '@/components/StupWizard';
|
||||||
import EquipmentManagement from '@/components/EquipmentManagement';
|
import EquipmentManagement from '@/components/EquipmentManagement';
|
||||||
import UserVideo from '@/components/UserVideo';
|
import UserVideo from '@/components/UserVideo';
|
||||||
import { role } from '@/config/role';
|
import { role } from '@/config/role';
|
||||||
import { fixWebmDuration } from "webm-duration-fix-buffer";
|
const { ipcRenderer } = require('electron');
|
||||||
|
import * as path from 'path';
|
||||||
const { confirm } = Modal;
|
const { confirm } = Modal;
|
||||||
|
|
||||||
const { exec } = require('child_process');
|
const { exec } = require('child_process');
|
||||||
const fs = require('fs').promises;
|
const fs = require('fs').promises;
|
||||||
dayjs.extend(durationPlugin);
|
dayjs.extend(durationPlugin);
|
||||||
|
|
@ -540,13 +542,53 @@ const Meeting: React.FC = () => {
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (recorder) {
|
if (recorder) {
|
||||||
recorder.start();
|
recorder.start();
|
||||||
recorder.ondataavailable = async (event: any) => {
|
recorder.ondataavailable = (event: any) => {
|
||||||
const blob = await fixWebmDuration(event.data);
|
const blob = new Blob([event.data], {
|
||||||
|
type: 'video/webm',
|
||||||
|
});
|
||||||
const reader = new FileReader() as any;
|
const reader = new FileReader() as any;
|
||||||
reader.onload = async () => {
|
reader.onload = async () => {
|
||||||
|
try {
|
||||||
|
const userDataPath = await ipcRenderer.invoke('get-user-data-path');
|
||||||
|
|
||||||
|
// 获取当前日期并格式化
|
||||||
|
const date = new Date();
|
||||||
|
const year = date.getFullYear();
|
||||||
|
const month = date.getMonth() + 1; // JavaScript月份从0开始
|
||||||
|
const day = date.getDate();
|
||||||
|
const hours = date.getHours();
|
||||||
|
const minutes = date.getMinutes();
|
||||||
|
const formattedDate = `${year}年${month}月${day}日${hours}时${minutes}分`;
|
||||||
|
|
||||||
|
|
||||||
const setting = await JSON.parse(storage.getItem('setting') as string)
|
const setting = await JSON.parse(storage.getItem('setting') as string)
|
||||||
const buffer = Buffer.from(reader.result);
|
const buffer = Buffer.from(reader.result);
|
||||||
await fs.writeFile(`${setting.recordingFilesPath}会议录制_${state.roomName}_${state.channelId}_${+new Date()}.webm`, buffer, {});
|
const mp4Path=`${setting.recordingFilesPath}会议录制_${state.roomName}_${state.channelId}_${formattedDate}_beforehanlder.mp4`;
|
||||||
|
await fs.writeFile(mp4Path, buffer);
|
||||||
|
|
||||||
|
// 获取应用程序安装路径
|
||||||
|
const ffmpegPath = path.join(userDataPath, "ffmpeg.exe");
|
||||||
|
|
||||||
|
const inputFilePath = mp4Path; // 输入文件路径
|
||||||
|
const outputFilePath = mp4Path.replace('_beforehanlder',''); // 输出文件路径
|
||||||
|
const command = `${ffmpegPath} -i "${inputFilePath}" -vcodec copy -acodec copy "${outputFilePath}"`;
|
||||||
|
|
||||||
|
exec(command, (error:any, stdout:any, stderr:any) => {
|
||||||
|
if (error) {
|
||||||
|
console.error('Error executing ffmpeg command:', error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 删除输入文件
|
||||||
|
fs.unlink(inputFilePath, (err:any) => {
|
||||||
|
if (err) {
|
||||||
|
console.error('Error deleting input file:', err);
|
||||||
|
} else {
|
||||||
|
console.log('Input file deleted successfully.');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
confirm({
|
confirm({
|
||||||
title: '提示',
|
title: '提示',
|
||||||
icon: <ExclamationCircleFilled />,
|
icon: <ExclamationCircleFilled />,
|
||||||
|
|
@ -565,7 +607,14 @@ const Meeting: React.FC = () => {
|
||||||
onCancel() {
|
onCancel() {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
};
|
|
||||||
|
});
|
||||||
|
} catch (err) {
|
||||||
|
console.error('处理录制时出错:', err);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
reader.readAsArrayBuffer(blob);
|
reader.readAsArrayBuffer(blob);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
@ -1285,6 +1334,8 @@ const Meeting: React.FC = () => {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// 开关麦克风
|
// 开关麦克风
|
||||||
const postOpenMicrApi = async (enableMicr: boolean, uid: string, isAll: boolean, isMessage: boolean = false): Promise<void> => {
|
const postOpenMicrApi = async (enableMicr: boolean, uid: string, isAll: boolean, isMessage: boolean = false): Promise<void> => {
|
||||||
if (isAll) {
|
if (isAll) {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue