preload.js 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. console.log('Preload script loaded');
  2. const {contextBridge, ipcRenderer} = require('electron');
  3. contextBridge.exposeInMainWorld('electronAPI', {
  4. openFileManager: async () => {
  5. try {
  6. return await ipcRenderer.invoke('dialog:open');
  7. } catch (error) {
  8. console.error('打开文件管理器时出错:', error);
  9. throw error;
  10. }
  11. },
  12. downloadFile: async (url, fileName, savePath, overwriteFlag, dialogFlag, requestType, data) => {
  13. try {
  14. return await ipcRenderer.invoke('download-file', { url, fileName, savePath, overwriteFlag, dialogFlag, requestType, data });
  15. } catch (error) {
  16. console.error('下载文件时出错:', error);
  17. return { success: false, error: error.message };
  18. }
  19. },
  20. deleteFile: (fileName, savePath) => ipcRenderer.send('delete-file', {fileName, savePath}),
  21. onDeleteFileResponse: (callback) => ipcRenderer.once('delete-file-response', callback),
  22. uploadFile: async (filePath, uploadUrl) => ipcRenderer.send('upload-file', {filePath, uploadUrl}),
  23. onUploadFileResponse: (callback) => ipcRenderer.once('upload-file-response', callback),
  24. // dockerImport 函数现在接受两个参数:filePath 和 tag
  25. dockerImport: (filePath, tag) => {
  26. console.log('docker导入算法镜像文件:', filePath, '本地镜像版本:', tag);
  27. // 发送事件到主进程,并带上文件路径和文件名作为参数
  28. ipcRenderer.send('docker-import', filePath, tag);
  29. },
  30. onDockerImportResponse: (callback) => ipcRenderer.once('docker-import-response', callback),
  31. updateMap: async (container_name, file_path) => {
  32. // 异步
  33. ipcRenderer.send('update-map', {container_name, file_path});
  34. },
  35. onUpdateMapResponse: (callback) => ipcRenderer.once('update-map-response', callback),
  36. runSimulation: async (random_flag, count, obstacle_flag, default_start_flag, default_end_flag, start_point, end_point) => {
  37. // 异步
  38. ipcRenderer.send('run-simulation', {random_flag, count, obstacle_flag, default_start_flag, default_end_flag, start_point, end_point});
  39. },
  40. onRunSimulationResponse: (callback) => ipcRenderer.once('run-simulation-response', callback),
  41. generateWorld: (rosbag_path) => {
  42. // 发送事件到主进程
  43. ipcRenderer.send('generate-world', {rosbag_path});
  44. },
  45. onGenerateWorldResponse: (callback) => ipcRenderer.once('generate-world-response', callback),
  46. startContainer: (zip_file_path, image_name, container_name) => {
  47. // 发送事件到主进程
  48. ipcRenderer.send('start-container', {zip_file_path, image_name, container_name});
  49. },
  50. onStartContainerResponse: (callback) => ipcRenderer.once('start-container-response', callback),
  51. processEvaluationFiles: async (N, equipmentNo, sceneNo) => {
  52. return await ipcRenderer.invoke('process-evaluation-files', {N, equipmentNo, sceneNo});
  53. },
  54. processMapUpdateFiles: async (equipmentNo, timeStamp) => {
  55. return await ipcRenderer.invoke('process-map-update-files', {equipmentNo, timeStamp});
  56. },
  57. });