preload.js 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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: (sudoPassword, filePath, tag) => {
  31. console.log('sudo密码为:', sudoPassword);
  32. console.log('docker导入算法镜像文件:', filePath, '本地镜像版本:', tag);
  33. // 发送事件到主进程,并带上文件路径和文件名作为参数
  34. ipcRenderer.send('docker-import',sudoPassword, filePath, tag);
  35. },
  36. generateWorld: (rosbag_path) => {
  37. // 发送事件到主进程
  38. ipcRenderer.send('generate-world', {rosbag_path});
  39. },
  40. onGenerateWorldResult: (callback) => ipcRenderer.on('generate-world-result', callback),
  41. downloadFile: async (url, fileName, savePath) => {
  42. try {
  43. return await ipcRenderer.invoke('download-file', { url, fileName, savePath });
  44. } catch (error) {
  45. console.error('下载文件时出错:', error);
  46. return { success: false, error: error.message };
  47. }
  48. },
  49. deleteFile: (fileName, savePath) => ipcRenderer.send('delete-file', {fileName, savePath}),
  50. onDeleteFileResponse: (callback) => ipcRenderer.on('delete-file-response', callback),
  51. });