camera.js 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  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. const { windowManager } = require('node-window-manager');
  9. // 检查并读取配置文件
  10. function readConfigFile(configPath) {
  11. try {
  12. // 检查文件是否存在
  13. if (!fs.existsSync(configPath)) {
  14. // 创建默认配置文件
  15. const defaultConfig = {};
  16. fs.writeFileSync(configPath, JSON.stringify(defaultConfig, null, 2));
  17. return defaultConfig;
  18. }
  19. // 读取配置文件
  20. return JSON.parse(fs.readFileSync(configPath, 'utf8'));
  21. } catch (error) {
  22. console.error('读取配置文件时出错:', error);
  23. throw error;
  24. }
  25. }
  26. const configPath = path.join(__dirname, '..', 'config', 'app.config.json');
  27. const config = readConfigFile(configPath);
  28. async function checkCameraControlCmdExists() {
  29. try {
  30. // 获取 digiCamControl 文件夹路径
  31. const digiCamControlPath = config.digiCamControl;
  32. // 拼接 CameraControlCmd.exe 的完整路径
  33. const exePath = path.join(digiCamControlPath, 'CameraControl.exe');
  34. // 检查文件是否存在
  35. const exists = await fs.promises.access(exePath, fs.constants.F_OK)
  36. .then(() => true)
  37. .catch(() => false);
  38. if (!exists) {
  39. // 弹出文件夹选择对话框
  40. const { canceled, filePaths } = await dialog.showOpenDialog({
  41. title: '选择 digiCamControl 文件夹',
  42. properties: ['openDirectory']
  43. });
  44. if (!canceled && filePaths.length > 0) {
  45. const selectedPath = filePaths[0];
  46. // 更新 app.config.json 中的 digiCamControl 值
  47. config.digiCamControl = selectedPath;
  48. fs.writeFileSync(configPath, JSON.stringify(config, null, 2));
  49. return true; // 重新检查文件是否存在
  50. } else {
  51. console.error('用户未选择文件夹');
  52. return false;
  53. }
  54. }
  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. function closeCameraControlTips() {
  93. try {
  94. const windows = windowManager.getWindows();
  95. for (const window of windows) {
  96. const title = window.getTitle();
  97. if (title === "digiCamControl by Duka Istvan") {
  98. console.log(title);
  99. window.hide()
  100. break;
  101. }
  102. }
  103. }catch (e) {
  104. console.log(e)
  105. }
  106. }
  107. class CameraController extends Controller {
  108. constructor(ctx) {
  109. super(ctx);
  110. }
  111. async connect() {
  112. try {
  113. await checkCameraControlCmdExists()
  114. await CMD('All_Minimize')
  115. closeCameraControlTips()
  116. const res = await getParams('iso')
  117. if(res === '未将对象引用设置到对象的实例。'){
  118. return {
  119. status:-1,
  120. msg:"相机未连接,请链接相机。",
  121. }
  122. }
  123. return {
  124. status:2,
  125. msg:res,
  126. }
  127. return true;
  128. } catch (error) {
  129. return {
  130. status:-1,
  131. msg:"请安装digiCamControl软件,并打开digiCamControl软件的web服务,端口为5513",
  132. }
  133. }
  134. }
  135. /**
  136. * 启动预览
  137. */
  138. async liveShow() {
  139. try {
  140. await liveShow();
  141. await CMD('All_Minimize')
  142. return true;
  143. } catch (error) {
  144. console.error('eeee启动直播失败:', error);
  145. throw error;
  146. }
  147. }
  148. /**
  149. * 结束预览
  150. */
  151. async liveHide() {
  152. try {
  153. await liveHide();
  154. return true;
  155. } catch (error) {
  156. throw error;
  157. }
  158. }
  159. /**
  160. * 设置参数
  161. */
  162. async setParams(params) {
  163. try {
  164. console.log(params);
  165. await setParams(params);
  166. return true;
  167. } catch (error) {
  168. throw error;
  169. }
  170. }
  171. async takePictures() {
  172. try {
  173. await capture();
  174. return true;
  175. } catch (error) {
  176. throw error;
  177. }
  178. }
  179. // 示例:使用 fetchData 函数进行 HTTP 请求
  180. async fetchExampleData() {
  181. const options = {
  182. hostname: 'example.com',
  183. port: 443,
  184. path: '/api/data',
  185. method: 'GET'
  186. };
  187. try {
  188. const data = await fetchData(options);
  189. console.log('Fetched data:', data);
  190. return data;
  191. } catch (error) {
  192. console.error('Fetch data failed:', error);
  193. throw error;
  194. }
  195. }
  196. }
  197. CameraController.toString = () => '[class CameraController]';
  198. module.exports = CameraController;