|
|
@ -17,32 +17,32 @@ import java.awt.event.MouseEvent; |
|
|
|
* Create server tray. |
|
|
|
* Create server tray. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public class ServerTray { |
|
|
|
public class ServerTray { |
|
|
|
|
|
|
|
|
|
|
|
private static ServerTray INSTANCE; |
|
|
|
private static ServerTray INSTANCE; |
|
|
|
|
|
|
|
|
|
|
|
private MenuItem startMenu; |
|
|
|
private MenuItem startMenu; |
|
|
|
|
|
|
|
|
|
|
|
private MenuItem stopMenu; |
|
|
|
private MenuItem stopMenu; |
|
|
|
|
|
|
|
|
|
|
|
private Image trayStartedImage = BaseUtils.readImage("/com/fr/base/images/oem/trayStarted.png"); |
|
|
|
private Image trayStartedImage = BaseUtils.readImage("/com/fr/base/images/oem/trayStarted.png"); |
|
|
|
|
|
|
|
|
|
|
|
private Image trayStoppedImage = BaseUtils.readImage("/com/fr/base/images/oem/trayStopped.png"); |
|
|
|
private Image trayStoppedImage = BaseUtils.readImage("/com/fr/base/images/oem/trayStopped.png"); |
|
|
|
|
|
|
|
|
|
|
|
private ServerManageFrame serverManageFrame; |
|
|
|
private ServerManageFrame serverManageFrame; |
|
|
|
|
|
|
|
|
|
|
|
private TrayIcon trayIcon; |
|
|
|
private TrayIcon trayIcon; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private ServerTray() { |
|
|
|
private ServerTray() { |
|
|
|
|
|
|
|
|
|
|
|
listen(); |
|
|
|
listen(); |
|
|
|
//p:首先构建右键菜单
|
|
|
|
//p:首先构建右键菜单
|
|
|
|
PopupMenu popup = new PopupMenu(); |
|
|
|
PopupMenu popup = new PopupMenu(); |
|
|
|
MenuItem manangeMenu = new MenuItem(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Basic_Server_Open_Service_Manager")); |
|
|
|
MenuItem manangeMenu = new MenuItem(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Basic_Server_Open_Service_Manager")); |
|
|
|
manangeMenu.addActionListener(new ActionListener() { |
|
|
|
manangeMenu.addActionListener(new ActionListener() { |
|
|
|
|
|
|
|
|
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
|
|
|
|
|
|
|
|
serverManageFrame = ServerManageFrame.getServerManageFrame(); |
|
|
|
serverManageFrame = ServerManageFrame.getServerManageFrame(); |
|
|
|
if (!serverManageFrame.isVisible()) { |
|
|
|
if (!serverManageFrame.isVisible()) { |
|
|
|
serverManageFrame.setVisible(true); |
|
|
|
serverManageFrame.setVisible(true); |
|
|
@ -55,9 +55,9 @@ public class ServerTray { |
|
|
|
MenuItem exitMenu = new MenuItem(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Basic_M_Exit")); |
|
|
|
MenuItem exitMenu = new MenuItem(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Basic_M_Exit")); |
|
|
|
//创建打开监听器
|
|
|
|
//创建打开监听器
|
|
|
|
ActionListener startListener = new ActionListener() { |
|
|
|
ActionListener startListener = new ActionListener() { |
|
|
|
|
|
|
|
|
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
try { |
|
|
|
FineEmbedServer.start(); |
|
|
|
FineEmbedServer.start(); |
|
|
|
} catch (Exception exp) { |
|
|
|
} catch (Exception exp) { |
|
|
@ -66,9 +66,9 @@ public class ServerTray { |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
ActionListener stopListener = new ActionListener() { |
|
|
|
ActionListener stopListener = new ActionListener() { |
|
|
|
|
|
|
|
|
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
try { |
|
|
|
FineEmbedServer.stop(); |
|
|
|
FineEmbedServer.stop(); |
|
|
|
} catch (Throwable exp) { |
|
|
|
} catch (Throwable exp) { |
|
|
@ -80,13 +80,13 @@ public class ServerTray { |
|
|
|
stopMenu.addActionListener(stopListener); |
|
|
|
stopMenu.addActionListener(stopListener); |
|
|
|
//创建退出菜单监听器
|
|
|
|
//创建退出菜单监听器
|
|
|
|
ActionListener exitListener = new ActionListener() { |
|
|
|
ActionListener exitListener = new ActionListener() { |
|
|
|
|
|
|
|
|
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
public void actionPerformed(ActionEvent e) { |
|
|
|
|
|
|
|
|
|
|
|
exit(); |
|
|
|
exit(); |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
exitMenu.addActionListener(exitListener); |
|
|
|
exitMenu.addActionListener(exitListener); |
|
|
|
popup.add(manangeMenu); |
|
|
|
popup.add(manangeMenu); |
|
|
|
popup.addSeparator(); |
|
|
|
popup.addSeparator(); |
|
|
@ -94,18 +94,18 @@ public class ServerTray { |
|
|
|
popup.add(stopMenu); |
|
|
|
popup.add(stopMenu); |
|
|
|
popup.addSeparator(); |
|
|
|
popup.addSeparator(); |
|
|
|
popup.add(exitMenu); |
|
|
|
popup.add(exitMenu); |
|
|
|
|
|
|
|
|
|
|
|
//p:开始创建托盘.
|
|
|
|
//p:开始创建托盘.
|
|
|
|
trayIcon = new TrayIcon(trayStartedImage, com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Basic_Server_Embedded_Server"), popup); |
|
|
|
trayIcon = new TrayIcon(trayStartedImage, com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Basic_Server_Embedded_Server"), popup); |
|
|
|
trayIcon.setImageAutoSize(true); |
|
|
|
trayIcon.setImageAutoSize(true); |
|
|
|
trayIcon.addMouseListener(new MouseAdapter() { |
|
|
|
trayIcon.addMouseListener(new MouseAdapter() { |
|
|
|
|
|
|
|
|
|
|
|
public void mouseClicked(MouseEvent e) { |
|
|
|
public void mouseClicked(MouseEvent e) { |
|
|
|
|
|
|
|
|
|
|
|
if (e.getClickCount() < 2) { |
|
|
|
if (e.getClickCount() < 2) { |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
ServerManageFrame serverManageFrame = ServerManageFrame.getServerManageFrame(); |
|
|
|
ServerManageFrame serverManageFrame = ServerManageFrame.getServerManageFrame(); |
|
|
|
if (!serverManageFrame.isVisible()) { |
|
|
|
if (!serverManageFrame.isVisible()) { |
|
|
|
serverManageFrame.setVisible(true); |
|
|
|
serverManageFrame.setVisible(true); |
|
|
@ -113,56 +113,56 @@ public class ServerTray { |
|
|
|
serverManageFrame.toFront();//p:到第一个.
|
|
|
|
serverManageFrame.toFront();//p:到第一个.
|
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
TrayIcon[] icons = SystemTray.getSystemTray().getTrayIcons(); |
|
|
|
TrayIcon[] icons = SystemTray.getSystemTray().getTrayIcons(); |
|
|
|
for (TrayIcon icon : icons) { |
|
|
|
for (TrayIcon icon : icons) { |
|
|
|
SystemTray.getSystemTray().remove(icon); |
|
|
|
SystemTray.getSystemTray().remove(icon); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
try { |
|
|
|
SystemTray.getSystemTray().add(trayIcon); |
|
|
|
SystemTray.getSystemTray().add(trayIcon); |
|
|
|
} catch (AWTException e) { |
|
|
|
} catch (AWTException e) { |
|
|
|
System.err.println("Can not create the System Tray:" + e); |
|
|
|
System.err.println("Can not create the System Tray:" + e); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
checkPopupMenuItemEnabled(); |
|
|
|
checkPopupMenuItemEnabled(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void listen() { |
|
|
|
private void listen() { |
|
|
|
|
|
|
|
|
|
|
|
ListenerAdaptor listenerAdaptor = new ListenerAdaptor() { |
|
|
|
ListenerAdaptor listenerAdaptor = new ListenerAdaptor() { |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
protected void on(Event event) { |
|
|
|
protected void on(Event event) { |
|
|
|
|
|
|
|
|
|
|
|
checkPopupMenuItemEnabled(); |
|
|
|
checkPopupMenuItemEnabled(); |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
EventDispatcher.listen(EmbedServerEvent.AfterStart, listenerAdaptor); |
|
|
|
EventDispatcher.listen(EmbedServerEvent.AfterStart, listenerAdaptor); |
|
|
|
EventDispatcher.listen(EmbedServerEvent.AfterStop, listenerAdaptor); |
|
|
|
EventDispatcher.listen(EmbedServerEvent.AfterStop, listenerAdaptor); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void exit() { |
|
|
|
private void exit() { |
|
|
|
|
|
|
|
|
|
|
|
FineEmbedServer.stop(); |
|
|
|
FineEmbedServer.stop(); |
|
|
|
SystemTray.getSystemTray().remove(trayIcon); |
|
|
|
SystemTray.getSystemTray().remove(trayIcon); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void checkPopupMenuItemEnabled() { |
|
|
|
private void checkPopupMenuItemEnabled() { |
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
try { |
|
|
|
if (FineEmbedServer.isRunning()) { |
|
|
|
if (FineEmbedServer.isRunning()) { |
|
|
|
startMenu.setEnabled(false); |
|
|
|
startMenu.setEnabled(false); |
|
|
|
stopMenu.setEnabled(true); |
|
|
|
stopMenu.setEnabled(true); |
|
|
|
|
|
|
|
|
|
|
|
trayIcon.setImage(trayStartedImage); |
|
|
|
trayIcon.setImage(trayStartedImage); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
startMenu.setEnabled(true); |
|
|
|
startMenu.setEnabled(true); |
|
|
|
stopMenu.setEnabled(false); |
|
|
|
stopMenu.setEnabled(false); |
|
|
|
|
|
|
|
|
|
|
|
trayIcon.setImage(trayStoppedImage); |
|
|
|
trayIcon.setImage(trayStoppedImage); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (serverManageFrame != null) { |
|
|
|
if (serverManageFrame != null) { |
|
|
|
serverManageFrame.checkButtonEnabled(); |
|
|
|
serverManageFrame.checkButtonEnabled(); |
|
|
|
serverManageFrame.repaint(); |
|
|
|
serverManageFrame.repaint(); |
|
|
@ -171,10 +171,9 @@ public class ServerTray { |
|
|
|
FRContext.getLogger().error(exp.getMessage(), exp); |
|
|
|
FRContext.getLogger().error(exp.getMessage(), exp); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public static void init() { |
|
|
|
public static void init() { |
|
|
|
|
|
|
|
if (INSTANCE == null) |
|
|
|
INSTANCE = new ServerTray(); |
|
|
|
INSTANCE = new ServerTray(); |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |