Mercurial > hg > Applications > TreeVNC
view src/viewer_swing/java/com/glavsoft/viewer/ConnectionPresenter.java @ 468:f8a88cdb857b
fix retina frame buffer position
author | mir3636 |
---|---|
date | Fri, 29 Jul 2016 15:30:48 +0900 (2016-07-29) |
parents | fd803266ade7 |
children | 37b1e8cbc6bb |
line wrap: on
line source
// Copyright (C) 2010, 2011, 2012, 2013 GlavSoft LLC. // All rights reserved. // //------------------------------------------------------------------------- // This file is part of the TightVNC software. Please visit our Web site: // // http://www.tightvnc.com/ // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 2 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License along // with this program; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. //------------------------------------------------------------------------- // package com.glavsoft.viewer; import com.glavsoft.rfb.protocol.ProtocolSettings; import com.glavsoft.transport.Reader; import com.glavsoft.transport.Writer; import com.glavsoft.utils.Strings; import com.glavsoft.viewer.mvp.Presenter; import com.glavsoft.viewer.mvp.View; import com.glavsoft.viewer.swing.*; import com.glavsoft.viewer.swing.gui.ConnectionView; import com.glavsoft.viewer.swing.gui.ConnectionsHistory; import java.net.Socket; import java.util.logging.Logger; /** * @author dime at tightvnc.com */ public class ConnectionPresenter extends Presenter { public static final String PROPERTY_HOST_NAME = "HostName"; public static final String PROPERTY_RFB_PORT_NUMBER = "PortNumber"; public static final String PROPERTY_USE_SSH = "UseSsh"; private static final String PROPERTY_SSH_USER_NAME = "SshUserName"; private static final String PROPERTY_SSH_HOST_NAME = "SshHostName"; private static final String PROPERTY_SSH_PORT_NUMBER = "SshPortNumber"; private static final String PROPERTY_STATUS_BAR_MESSAGE = "Message"; private static final String PROPERTY_CONNECTION_IN_PROGRESS = "ConnectionInProgress"; public static final String CONNECTION_PARAMS_MODEL = "ConnectionParamsModel"; public static final String CONNECTIONS_HISTORY_MODEL = "ConnectionsHistoryModel"; public static final String CONNECTION_VIEW = "ConnectionView"; private final boolean hasSshSupport; private final boolean allowInteractive; private ConnectionsHistory connectionsHistory; private ProtocolSettings rfbSettings; private UiSettings uiSettings; private final Logger logger; private RfbConnectionWorker rfbConnectionWorker; private AbstractConnectionWorkerFactory connectionWorkerFactory; private NetworkConnectionWorker networkConnectionWorker; private boolean needReconnection = true; private boolean isTreeVNC = false; private boolean cuiVersion; private boolean noConnection = false; public ViewerInterface viewer; private ConnectionParams connectionParams; private short reconnectingId = -1; private int frameSizeWidth; // contains multi screens private int frameSizeHeight; private int singleWidth = 0; // requested single screen in frame buffer private int singleHeight = 0; private int retinaScale = 1; // we don't use it now private int x; // requested single screen offset private int y; public short getReconnectingId() { return reconnectingId; } public void setReconnectingId(short reconnectingId) { this.reconnectingId = reconnectingId; } public ConnectionParams getConnectionParams() { return connectionParams; } public void setConnectionParams(ConnectionParams connectionParams) { this.connectionParams = connectionParams; } public ConnectionPresenter(boolean hasSshSupport, boolean allowInteractive) { this.hasSshSupport = hasSshSupport; this.allowInteractive = allowInteractive; logger = Logger.getLogger(getClass().getName()); } public void startConnection(ProtocolSettings rfbSettings, UiSettings uiSettings, int paramSettingsMask, boolean exchangeSocket, Reader is, Writer os) throws IllegalStateException { this.rfbSettings = rfbSettings; this.uiSettings = uiSettings; if ( ! isModelRegisteredByName(CONNECTION_PARAMS_MODEL)) { throw new IllegalStateException("No Connection Params model added."); } if(!isTreeVNC) { connectionsHistory = new ConnectionsHistory(); addModel(CONNECTIONS_HISTORY_MODEL, connectionsHistory); syncModels(paramSettingsMask); } if (exchangeSocket) { rfbConnectionWorker.startVNCConnectionWithSocket(is, os); return; } if (allowInteractive) { show(); populate(); } else { if (!noConnection) connect(); } } public void setNoConnection(boolean c){ noConnection = c; needReconnection = false; } public void setUseSsh(boolean useSsh) { setModelProperty(PROPERTY_USE_SSH, useSsh, boolean.class); } public void submitConnection(String hostName) throws WrongParameterException { if (Strings.isTrimmedEmpty(hostName)) { throw new WrongParameterException("Host name is empty", PROPERTY_HOST_NAME); } setModelProperty(PROPERTY_HOST_NAME, hostName); final String rfbPort = (String) getViewPropertyOrNull(PROPERTY_RFB_PORT_NUMBER); setModelProperty(PROPERTY_RFB_PORT_NUMBER, rfbPort); try { throwPossiblyHappenedException(); } catch (Throwable e) { throw new WrongParameterException("Wrong Port", PROPERTY_HOST_NAME); } setSshOptions(); saveHistory(); populateFrom(CONNECTIONS_HISTORY_MODEL); connect(); } public void saveHistory() { final ConnectionParams cp = (ConnectionParams) getModel(CONNECTION_PARAMS_MODEL); if (cp == null) return; connectionsHistory.reorder(cp, rfbSettings, uiSettings); connectionsHistory.save(); } private void connect() { final ConnectionParams connectionParams = (ConnectionParams) getModel(CONNECTION_PARAMS_MODEL); if(!cuiVersion) networkConnectionWorker = connectionWorkerFactory.createNetworkConnectionWorker(); else networkConnectionWorker = new SwingNetworkConnectionWorker(null); networkConnectionWorker.setConnectionParams(connectionParams); networkConnectionWorker.setPresenter(this); networkConnectionWorker.setHasSshSupport(hasSshSupport); networkConnectionWorker.execute(); } public void connectionFailed() { cancelConnection(); if (isTreeVNC) return; if (allowInteractive) { enableConnectionDialog(); } else { connect(); } } public void connectionCancelled() { cancelConnection(); if (isTreeVNC) return; if (allowInteractive) { enableConnectionDialog(); } else { final ConnectionView connectionView = (ConnectionView) getView(CONNECTION_VIEW); if (connectionView != null) { connectionView.closeApp(); } } } private void enableConnectionDialog() { setViewProperty(PROPERTY_CONNECTION_IN_PROGRESS, false, boolean.class); } public void successfulNetworkConnection(Socket workingSocket) { // EDT logger.info("Connected"); showMessage("Connected"); rfbConnectionWorker = connectionWorkerFactory.createRfbConnectionWorker(); rfbConnectionWorker.setWorkingSocket(workingSocket); rfbConnectionWorker.setRfbSettings(rfbSettings); rfbConnectionWorker.setUiSettings(uiSettings); rfbConnectionWorker.setConnectionString( getModelProperty(PROPERTY_HOST_NAME) + ":" + getModelProperty(PROPERTY_RFB_PORT_NUMBER)); rfbConnectionWorker.execute(); } public void successfulRfbConnection() { enableConnectionDialog(); getView(CONNECTION_VIEW).closeView(); } public void cancelConnection() { if (networkConnectionWorker != null) { networkConnectionWorker.cancel(); } if (rfbConnectionWorker != null) { rfbConnectionWorker.cancel(); } } public void showConnectionErrorDialog(String message) { if (!isTreeVNC) return; final ConnectionView connectionView = (ConnectionView) getView(CONNECTION_VIEW); if (connectionView != null) { connectionView.showConnectionErrorDialog(message); } } public void showPortErrorDialog(String message) { if (!isTreeVNC) return; final ConnectionView connectionView = (ConnectionView) getView(CONNECTION_VIEW); if (connectionView != null) { connectionView.showErrorDialog(message); } } public void showReconnectDialog(String errorTitle, String errorMessage) { if (!isTreeVNC) return; final ConnectionView connectionView = (ConnectionView) getView(CONNECTION_VIEW); if (connectionView != null && needReconnection) { connectionView.showReconnectDialog(errorTitle, errorMessage); } } public boolean showShareSoundDialog() { final ConnectionView connectionView = (ConnectionView) getView(CONNECTION_VIEW); boolean shareSound = false; if (connectionView != null) { shareSound = connectionView.showShareSoundDialog(); } return shareSound; } private void setSshOptions() { if (hasSshSupport) { try { final boolean useSsh = (Boolean)getViewProperty(PROPERTY_USE_SSH); setModelProperty(PROPERTY_USE_SSH, useSsh, boolean.class); } catch (PropertyNotFoundException e) { //nop } setModelProperty(PROPERTY_SSH_USER_NAME, getViewPropertyOrNull(PROPERTY_SSH_USER_NAME)); setModelProperty(PROPERTY_SSH_HOST_NAME, getViewPropertyOrNull(PROPERTY_SSH_HOST_NAME)); setModelProperty(PROPERTY_SSH_PORT_NUMBER, getViewPropertyOrNull(PROPERTY_SSH_PORT_NUMBER)); setViewProperty(PROPERTY_SSH_PORT_NUMBER, getModelProperty(PROPERTY_SSH_PORT_NUMBER)); } } private void syncModels(int paramSettingsMask) { final ConnectionParams cp = (ConnectionParams) getModel(CONNECTION_PARAMS_MODEL); final ConnectionParams mostSuitableConnection = connectionsHistory.getMostSuitableConnection(cp); cp.completeEmptyFieldsFrom(mostSuitableConnection); rfbSettings.copyDataFrom(connectionsHistory.getProtocolSettings(mostSuitableConnection), paramSettingsMask & 0xffff); uiSettings.copyDataFrom(connectionsHistory.getUiSettingsData(mostSuitableConnection), (paramSettingsMask >> 16) & 0xffff); if ( ! cp.isHostNameEmpty()) { connectionsHistory.reorder(cp, rfbSettings, uiSettings); } // protocolSettings.addListener(connectionsHistory); // uiSettings.addListener(connectionsHistory); } public void populateFromHistoryItem(ConnectionParams connectionParams) { setModelProperty(PROPERTY_HOST_NAME, connectionParams.hostName); setModelProperty(PROPERTY_RFB_PORT_NUMBER, connectionParams.getPortNumber(), int.class); setModelProperty(PROPERTY_USE_SSH, connectionParams.useSsh(), boolean.class); setModelProperty(PROPERTY_SSH_HOST_NAME, connectionParams.sshHostName); setModelProperty(PROPERTY_SSH_PORT_NUMBER, connectionParams.getSshPortNumber(), int.class); setModelProperty(PROPERTY_SSH_USER_NAME, connectionParams.sshUserName); populateFrom(CONNECTION_PARAMS_MODEL); rfbSettings.copyDataFrom(connectionsHistory.getProtocolSettings(connectionParams)); uiSettings.copyDataFrom(connectionsHistory.getUiSettingsData(connectionParams)); } public void clearHistory() { connectionsHistory.clear(); connectionsHistory.reorder((ConnectionParams) getModel(CONNECTION_PARAMS_MODEL), rfbSettings, uiSettings); populateFrom(CONNECTIONS_HISTORY_MODEL); clearMessage(); } public void showMessage(String message) { setViewProperty(PROPERTY_STATUS_BAR_MESSAGE, message); } public void clearMessage() { showMessage(""); } public void setConnectionWorkerFactory(AbstractConnectionWorkerFactory connectionWorkerFactory) { this.connectionWorkerFactory = connectionWorkerFactory; } public void reconnect(String predefinedPassword) { connectionWorkerFactory.setPredefinedPassword(predefinedPassword); if (allowInteractive) { clearMessage(); enableConnectionDialog(); show(); populate(); } else if (needReconnection) { connect(); } } public void clearPredefinedPassword() { connectionWorkerFactory.setPredefinedPassword(null); } public UiSettings getUiSettings() { return uiSettings; } public ProtocolSettings getRfbSettings() { return rfbSettings; } public boolean needReconnection() { return needReconnection; } public void setNeedReconnection(boolean need) { needReconnection = need; } public boolean allowInteractive() { return allowInteractive; } public void setIsTreeVNC(boolean flag) { isTreeVNC = flag; } public void setCuiVersion(boolean b) { cuiVersion = b; } public void setFrameSizeWidth(int frameSizeWidth) { this.frameSizeWidth = frameSizeWidth; } public void setFrameSizeHeight(int frameSizeHeight) { this.frameSizeHeight = frameSizeHeight; } public void setRetinaScale(int retinaScale) { this.retinaScale = retinaScale; } public void setX(int x) { this.x = x; } public void setY(int y) { this.y = y; } public int getFrameSizeWidth() { return frameSizeWidth; } public int getFrameSizeHeight() { return frameSizeHeight; } public int getRetinaScale() { return retinaScale; } public int getX() { return x; } public int getY() { return y; } public SwingViewerWindow getViewer() { if (rfbConnectionWorker != null) { return rfbConnectionWorker.getViewer(); } return null; } public Socket getSocket() { return rfbConnectionWorker.getSocket(); } public void startVNCConnection(Viewer viewer, boolean exchangeSocket, Reader is, Writer os) { this.viewer = viewer; final boolean hasJsch = viewer.checkJsch(); ConnectionView connectionView = new ConnectionView( viewer, // appWindowListener this, hasJsch); addView(CONNECTION_VIEW, connectionView); if (viewer.isApplet) { addView("AppletStatusStringView", new View() { @Override public void showView() { /*nop*/ } @Override public void closeView() { /*nop*/ } }); } SwingViewerWindowFactory viewerWindowFactory = new SwingViewerWindowFactory(viewer.isSeparateFrame, viewer.isApplet, viewer, viewer.width, viewer.height); setConnectionWorkerFactory( new SwingConnectionWorkerFactory(connectionView.getFrame(), viewer.passwordFromParams, this, viewerWindowFactory, viewer.myRfb)); setNeedReconnection(!viewer.noConnection); startConnection(viewer.settings, viewer.uiSettings, viewer.paramsMask, exchangeSocket, is, os); } public int getSingleWidth() { return singleWidth; } public int getSingleHeight() { return singleHeight; } public void setSingleWidth(int singleWidth) { this.singleWidth = singleWidth; } public void setSingleHeight(int signleHeight) { this.singleHeight = signleHeight; } }