camera.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. 'use strict';
  2. const path = require('path');
  3. const fs = require('fs');
  4. const { Controller } = require('ee-core');
  5. const { spawn } = require('child_process');
  6. const { liveShow, liveHide, setParams, capture, getParams,CMD } = require('../api/camera');
  7. const { dialog } = require('electron'); // 引入 electron 的 dialog 模块
  8. // 检查并读取配置文件
  9. function readConfigFile(configPath) {
  10. try {
  11. // 检查文件是否存在
  12. if (!fs.existsSync(configPath)) {
  13. // 创建默认配置文件
  14. const defaultConfig = {};
  15. fs.writeFileSync(configPath, JSON.stringify(defaultConfig, null, 2));
  16. return defaultConfig;
  17. }
  18. // 读取配置文件
  19. return JSON.parse(fs.readFileSync(configPath, 'utf8'));
  20. } catch (error) {
  21. console.error('读取配置文件时出错:', error);
  22. throw error;
  23. }
  24. }
  25. const configPath = path.join(__dirname, '..', 'config', 'app.config.json');
  26. const config = readConfigFile(configPath);
  27. async function checkCameraControlCmdExists() {
  28. try {
  29. // 获取 digiCamControl 文件夹路径
  30. const digiCamControlPath = config.digiCamControl;
  31. // 拼接 CameraControlCmd.exe 的完整路径
  32. const exePath = path.join(digiCamControlPath, 'CameraControl.exe');
  33. // 检查文件是否存在
  34. const exists = await fs.promises.access(exePath, fs.constants.F_OK)
  35. .then(() => true)
  36. .catch(() => false);
  37. if (!exists) {
  38. // 弹出文件夹选择对话框
  39. const { canceled, filePaths } = await dialog.showOpenDialog({
  40. title: '选择 digiCamControl 文件夹',
  41. properties: ['openDirectory']
  42. });
  43. if (!canceled && filePaths.length > 0) {
  44. const selectedPath = filePaths[0];
  45. // 更新 app.config.json 中的 digiCamControl 值
  46. config.digiCamControl = selectedPath;
  47. fs.writeFileSync(configPath, JSON.stringify(config, null, 2));
  48. return true; // 重新检查文件是否存在
  49. } else {
  50. console.error('用户未选择文件夹');
  51. return false;
  52. }
  53. }
  54. const res = await openCameraControlCmd();
  55. return res;
  56. } catch (error) {
  57. console.error('检查 CameraControlCmd.exe 是否存在时出错:', error);
  58. throw error;
  59. }
  60. }
  61. async function openCameraControlCmd() {
  62. return new Promise(async (resolve, reject) => {
  63. try {
  64. // 获取 digiCamControl 文件夹路径
  65. const digiCamControlPath = config.digiCamControl;
  66. // 拼接 CameraControlCmd.exe 的完整路径
  67. const exePath = path.join(digiCamControlPath, 'CameraControl.exe');
  68. // 检查文件是否存在
  69. await fs.promises.access(exePath, fs.constants.F_OK);
  70. try {
  71. const child = spawn(exePath);
  72. child.stdout.on('data', (data) => {
  73. resolve(true)
  74. });
  75. child.on('close', (code) => {
  76. if (code === 0) {
  77. reject(false)
  78. }
  79. });
  80. } catch (error) {
  81. console.error('error CameraControlCmd.exe:', error);
  82. throw error;
  83. }
  84. console.log('CameraControlCmd.exe start');
  85. } catch (error) {
  86. console.error('无法找到或运行 CameraControlCmd.exe:', error);
  87. throw error;
  88. }
  89. })
  90. }
  91. class CameraController extends Controller {
  92. constructor(ctx) {
  93. super(ctx);
  94. }
  95. async connect() {
  96. const win = this.app.electron.mainWindow;
  97. try {
  98. // win.setAlwaysOnTop(true); // 置顶
  99. console.log('aaaa')
  100. await checkCameraControlCmdExists()
  101. await CMD('All_Minimize')
  102. // win.setAlwaysOnTop(false); // 置顶
  103. const res = await getParams('iso')
  104. if(res === '未将对象引用设置到对象的实例。'){
  105. return {
  106. status:-1,
  107. msg:"相机未连接,请链接相机。",
  108. }
  109. }
  110. return {
  111. status:2,
  112. msg:res,
  113. }
  114. return true;
  115. } catch (error) {
  116. // win.setAlwaysOnTop(false); // 置顶
  117. return {
  118. status:-1,
  119. msg:"请安装digiCamControl软件,并打开digiCamControl软件的web服务,端口为5513",
  120. }
  121. }
  122. }
  123. /**
  124. * 启动预览
  125. */
  126. async liveShow() {
  127. try {
  128. await liveShow();
  129. await CMD('All_Minimize')
  130. return true;
  131. } catch (error) {
  132. console.error('eeee启动直播失败:', error);
  133. throw error;
  134. }
  135. }
  136. /**
  137. * 结束预览
  138. */
  139. async liveHide() {
  140. try {
  141. await liveHide();
  142. return true;
  143. } catch (error) {
  144. throw error;
  145. }
  146. }
  147. /**
  148. * 设置参数
  149. */
  150. async setParams(params) {
  151. try {
  152. console.log(params);
  153. await setParams(params);
  154. return true;
  155. } catch (error) {
  156. throw error;
  157. }
  158. }
  159. async takePictures() {
  160. try {
  161. await capture();
  162. return true;
  163. } catch (error) {
  164. throw error;
  165. }
  166. }
  167. // 示例:使用 fetchData 函数进行 HTTP 请求
  168. async fetchExampleData() {
  169. const options = {
  170. hostname: 'example.com',
  171. port: 443,
  172. path: '/api/data',
  173. method: 'GET'
  174. };
  175. try {
  176. const data = await fetchData(options);
  177. console.log('Fetched data:', data);
  178. return data;
  179. } catch (error) {
  180. console.error('Fetch data failed:', error);
  181. throw error;
  182. }
  183. }
  184. }
  185. CameraController.toString = () => '[class CameraController]';
  186. module.exports = CameraController;