preload.js 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. console.log('Preload script loaded');
  2. const {contextBridge, ipcRenderer} = require('electron');
  3. contextBridge.exposeInMainWorld('electronAPI', {
  4. openGazebo: () => {
  5. console.log('打开 gazebo');
  6. ipcRenderer.send('open-gazebo');
  7. },
  8. openRviz: () => {
  9. console.log('打开 rviz');
  10. ipcRenderer.send('open-rviz');
  11. },
  12. closeGazebo: () => {
  13. console.log('关闭 gazebo');
  14. ipcRenderer.send('close-gazebo');
  15. },
  16. closeRviz: () => {
  17. console.log('关闭 rviz');
  18. ipcRenderer.send('close-rviz');
  19. },
  20. openFileManager: async () => {
  21. try {
  22. const result = await ipcRenderer.invoke('dialog:open');
  23. return result;
  24. } catch (error) {
  25. console.error('打开文件管理器时出错:', error);
  26. throw error;
  27. }
  28. },
  29. // dockerImport 函数现在接受两个参数:filePath 和 tag
  30. dockerImport: (filePath, tag) => {
  31. console.log('docker导入算法镜像文件:', filePath, '本地镜像版本:', tag);
  32. // 发送事件到主进程,并带上文件路径和文件名作为参数
  33. ipcRenderer.send('docker-import', filePath, tag);
  34. },
  35. onDockerImportResponse: (callback) => ipcRenderer.on('docker-import-response', callback),
  36. runSimulation: async (obstacle_flag, default_start_flag, default_end_flag, start_point, end_point) => {
  37. // ipcRenderer.send('run-simulation', {obstacle_flag, default_start_flag, default_end_flag, start_point, end_point});
  38. try {
  39. const result = ipcRenderer.invoke('run-simulation', {obstacle_flag, default_start_flag, default_end_flag, start_point, end_point});
  40. return result;
  41. } catch (error) {
  42. console.error('执行仿真测试出错:', error);
  43. throw error;
  44. }
  45. },
  46. onRunSimulationResponse: (callback) => ipcRenderer.on('run-simulation-response', callback),
  47. generateWorld: (rosbag_path) => {
  48. // 发送事件到主进程
  49. ipcRenderer.send('generate-world', {rosbag_path});
  50. },
  51. onGenerateWorldResponse: (callback) => ipcRenderer.on('generate-world-result', callback),
  52. startContainer: (zip_file_path, image_name, container_name) => {
  53. // 发送事件到主进程
  54. ipcRenderer.send('start-container', {zip_file_path, image_name, container_name});
  55. },
  56. onStartContainerResponse: (callback) => ipcRenderer.on('start-container-result', callback),
  57. downloadFile: async (url, fileName, savePath, overwriteFlag) => {
  58. try {
  59. return await ipcRenderer.invoke('download-file', { url, fileName, savePath, overwriteFlag });
  60. } catch (error) {
  61. console.error('下载文件时出错:', error);
  62. return { success: false, error: error.message };
  63. }
  64. },
  65. deleteFile: (fileName, savePath) => ipcRenderer.send('delete-file', {fileName, savePath}),
  66. onDeleteFileResponse: (callback) => ipcRenderer.on('delete-file-response', callback),
  67. });