camera.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  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. console.log('aaaa2')
  55. const res = await openCameraControlCmd();
  56. return res;
  57. } catch (error) {
  58. console.error('检查 CameraControlCmd.exe 是否存在时出错:', error);
  59. throw error;
  60. }
  61. }
  62. async function openCameraControlCmd() {
  63. return new Promise(async (resolve, reject) => {
  64. try {
  65. // 获取 digiCamControl 文件夹路径
  66. const digiCamControlPath = config.digiCamControl;
  67. // 拼接 CameraControlCmd.exe 的完整路径
  68. const exePath = path.join(digiCamControlPath, 'CameraControl.exe');
  69. // 检查文件是否存在
  70. await fs.promises.access(exePath, fs.constants.F_OK);
  71. try {
  72. const child = spawn(exePath);
  73. child.stdout.on('data', (data) => {
  74. resolve(true)
  75. });
  76. child.on('close', (code) => {
  77. if (code === 0) {
  78. reject(false)
  79. }
  80. });
  81. } catch (error) {
  82. console.error('error CameraControlCmd.exe:', error);
  83. throw error;
  84. }
  85. console.log('CameraControlCmd.exe start');
  86. } catch (error) {
  87. console.error('无法找到或运行 CameraControlCmd.exe:', error);
  88. throw error;
  89. }
  90. })
  91. }
  92. class CameraController extends Controller {
  93. constructor(ctx) {
  94. super(ctx);
  95. }
  96. async connect() {
  97. const win = this.app.electron.mainWindow;
  98. try {
  99. // win.setAlwaysOnTop(true); // 置顶
  100. console.log('aaaa')
  101. await checkCameraControlCmdExists()
  102. await CMD('All_Minimize')
  103. // win.setAlwaysOnTop(false); // 置顶
  104. const res = await getParams('iso')
  105. if(res === '未将对象引用设置到对象的实例。'){
  106. return {
  107. status:-1,
  108. msg:"相机未连接,请链接相机。",
  109. }
  110. }
  111. return {
  112. status:2,
  113. msg:res,
  114. }
  115. return true;
  116. } catch (error) {
  117. // win.setAlwaysOnTop(false); // 置顶
  118. return {
  119. status:-1,
  120. msg:"请安装digiCamControl软件,并打开digiCamControl软件的web服务,端口为5513",
  121. }
  122. }
  123. }
  124. /**
  125. * 启动预览
  126. */
  127. async liveShow() {
  128. try {
  129. await liveShow();
  130. await CMD('All_Minimize')
  131. return true;
  132. } catch (error) {
  133. console.error('eeee启动直播失败:', error);
  134. throw error;
  135. }
  136. }
  137. /**
  138. * 结束预览
  139. */
  140. async liveHide() {
  141. try {
  142. await liveHide();
  143. return true;
  144. } catch (error) {
  145. throw error;
  146. }
  147. }
  148. /**
  149. * 设置参数
  150. */
  151. async setParams(params) {
  152. try {
  153. console.log(params);
  154. await setParams(params);
  155. return true;
  156. } catch (error) {
  157. throw error;
  158. }
  159. }
  160. async takePictures() {
  161. try {
  162. await capture();
  163. return true;
  164. } catch (error) {
  165. throw error;
  166. }
  167. }
  168. // 示例:使用 fetchData 函数进行 HTTP 请求
  169. async fetchExampleData() {
  170. const options = {
  171. hostname: 'example.com',
  172. port: 443,
  173. path: '/api/data',
  174. method: 'GET'
  175. };
  176. try {
  177. const data = await fetchData(options);
  178. console.log('Fetched data:', data);
  179. return data;
  180. } catch (error) {
  181. console.error('Fetch data failed:', error);
  182. throw error;
  183. }
  184. }
  185. }
  186. CameraController.toString = () => '[class CameraController]';
  187. module.exports = CameraController;