camera.js 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. 'use strict';
  2. const { Controller } = require('ee-core');
  3. const Log = require('ee-core/log');
  4. const { checkCameraControlCmdExists, closeCameraControlTips, isProcessRunning, onProcessClosed, removeProcessClosedListener } = require('../utils/camera');
  5. const {
  6. checkCamera,
  7. liveShow: liveShowApi, liveHide: liveHideApi, setParams, capture, getParams,CMD,captureLive,closeOtherWindow } = require('../api/camera');
  8. const { readConfigFile } = require('../utils/config');
  9. let isOPen = true
  10. let isSoftwareStarted = false; // 标记相机控制软件是否已经启动
  11. // 缓存相机列表数据,供多窗口共享
  12. let cachedCameraList = [];
  13. // 注册进程关闭事件监听器,当软件被关闭时重置标志
  14. onProcessClosed(() => {
  15. Log.info('相机控制软件已关闭,重置 isSoftwareStarted 标志');
  16. isSoftwareStarted = false;
  17. });
  18. class CameraController extends Controller {
  19. constructor(ctx) {
  20. super(ctx);
  21. }
  22. async connect(params = {}) {
  23. const isMultiCameraMode = params?.isMultiCameraMode ?? false;
  24. try {
  25. console.log('==================');
  26. console.log(readConfigFile());
  27. console.log('[CAMERA-DEBUG] connect() - isMultiCameraMode:', isMultiCameraMode);
  28. // 主动检测:即使 isSoftwareStarted 为 true,也要检查进程是否还在运行(兜底机制)
  29. console.log('[CAMERA-DEBUG] connect() 检查状态 - isSoftwareStarted:', isSoftwareStarted, 'isProcessRunning():', isProcessRunning());
  30. if (isSoftwareStarted && !isProcessRunning()) {
  31. console.log('[CAMERA-DEBUG] 检测到 isSoftwareStarted 为 true 但进程已关闭,重置标志');
  32. Log.info('检测到 isSoftwareStarted 为 true 但进程已关闭,重置标志');
  33. isSoftwareStarted = false;
  34. }
  35. if(readConfigFile().controlType === 'digiCamControl'){
  36. console.log('========1==========');
  37. // 主动检测:如果软件未启动或进程已关闭,先启动软件
  38. if (!isSoftwareStarted || !isProcessRunning()) {
  39. console.log('[CAMERA-DEBUG] 准备启动 digiCamControl - isSoftwareStarted:', isSoftwareStarted, 'isProcessRunning:', isProcessRunning());
  40. console.log('启动 digiCamControl 软件...');
  41. await checkCameraControlCmdExists();
  42. await CMD('All_Minimize');
  43. await closeCameraControlTips();
  44. isSoftwareStarted = true;
  45. console.log('digiCamControl 软件启动完成,等待初始化...');
  46. await new Promise(resolve => setTimeout(resolve, 5000)); // 等待软件初始化
  47. }
  48. // 获取相机参数
  49. let res = await getParams('iso').catch(e=>{
  50. console.log('getParams failed:', e);
  51. isOPen = false;
  52. return null;
  53. });
  54. if(res === '未将对象引用设置到对象的实例。' || !res){
  55. return {
  56. status:-1,
  57. msg: "相机硬件未连接,请检查相机连接。",
  58. }
  59. }
  60. return {
  61. status:2,
  62. msg:res,
  63. }
  64. }else{
  65. // SmartShooter 逻辑
  66. // 主动检测:如果软件未启动或进程已关闭,先启动软件
  67. console.log('[CAMERA-DEBUG] SmartShooter 分支 - isSoftwareStarted:', isSoftwareStarted, 'isProcessRunning():', isProcessRunning());
  68. if (!isSoftwareStarted || !isProcessRunning()) {
  69. console.log('[CAMERA-DEBUG] 准备启动 SmartShooter - isSoftwareStarted:', isSoftwareStarted, 'isProcessRunning:', isProcessRunning());
  70. Log.info('启动 SmartShooter 软件...');
  71. Log.info('isSoftwareStarted...'+isSoftwareStarted);
  72. Log.info('isProcessRunning...'+isProcessRunning);
  73. await checkCameraControlCmdExists();
  74. isSoftwareStarted = true;
  75. console.log('[CAMERA-DEBUG] checkCameraControlCmdExists() 完成,isSoftwareStarted:', isSoftwareStarted, 'isProcessRunning():', isProcessRunning());
  76. Log.info('SmartShooter 软件启动完成,等待初始化...');
  77. await new Promise(resolve => setTimeout(resolve, 10000)); // 等待软件初始化
  78. }
  79. // 检查相机状态
  80. let res = await checkCamera(isMultiCameraMode).catch(e=>{
  81. Log.info('checkCamera:'+e);
  82. isOPen = false;
  83. return { device_status: -1 }; // 返回错误状态,让后续逻辑处理
  84. })
  85. // 如果相机未连接
  86. if (res?.device_status === -1) {
  87. return {
  88. status: -1,
  89. msg: "相机硬件未连接,请检查相机连接。",
  90. };
  91. }
  92. if(res?.device_status === 2){
  93. isOPen = true;
  94. // 缓存相机列表数据
  95. if (res.CameraLists) {
  96. cachedCameraList = res.CameraLists;
  97. }
  98. return {
  99. ...res,
  100. status:2
  101. };
  102. }
  103. return {
  104. status:-1,
  105. msg:"相机未连接,请链接相机。",
  106. }
  107. }
  108. } catch (error) {
  109. let msg = '请安装SmartShooter5软件'
  110. if(readConfigFile().controlType === 'digiCamControl') msg = '请安装digiCamControl软件,并打开digiCamControl软件的web服务,端口为5513'
  111. return {
  112. status:-1,
  113. msg,
  114. }
  115. }
  116. }
  117. /**
  118. * 启动预览
  119. */
  120. async liveShow(data) {
  121. try {
  122. const point_name = data?.point_name || 'A';
  123. Log.info('liveShow:打开预览'+point_name);
  124. return await liveShowApi(point_name);
  125. if(readConfigFile().controlType === 'digiCamControl'){
  126. await CMD('All_Minimize')
  127. }
  128. return { success: true, point_name };
  129. } catch (error) {
  130. console.error('启动预览失败:', error);
  131. throw error;
  132. }
  133. }
  134. /**
  135. * 结束预览
  136. */
  137. async liveHide(data) {
  138. try {
  139. const point_name = data?.point_name || 'A';
  140. Log.info('liveShow:关闭'+point_name);
  141. return await liveHideApi(point_name);
  142. return { success: true, point_name };
  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(isLive=true) {
  160. try {
  161. if(isLive){
  162. await captureLive();
  163. }else{
  164. await capture();
  165. }
  166. return true;
  167. } catch (error) {
  168. throw error;
  169. }
  170. }
  171. /**
  172. * 获取缓存的相机列表(供设置页面等子窗口调用)
  173. */
  174. async getCameraList() {
  175. return {
  176. CameraLists: cachedCameraList,
  177. status: cachedCameraList.length > 0 ? 2 : 0,
  178. msg: cachedCameraList.length > 0 ? '获取成功' : '暂无相机列表'
  179. };
  180. }
  181. // 示例:使用 fetchData 函数进行 HTTP 请求
  182. async fetchExampleData() {
  183. const options = {
  184. hostname: 'example.com',
  185. port: 443,
  186. path: '/api/data',
  187. method: 'GET'
  188. };
  189. try {
  190. const data = await fetchData(options);
  191. console.log('Fetched data:', data);
  192. return data;
  193. } catch (error) {
  194. console.error('Fetch data failed:', error);
  195. throw error;
  196. }
  197. }
  198. }
  199. CameraController.toString = () => '[class CameraController]';
  200. module.exports = CameraController;