wisemapping-open-source/mindplot/src/main/javascript/Workspace.js

208 lines
7.5 KiB
JavaScript
Raw Normal View History

2010-11-21 06:43:54 +08:00
/*
2011-07-27 02:07:53 +08:00
* Copyright [2011] [wisemapping]
*
* Licensed under WiseMapping Public License, Version 1.0 (the "License").
* It is basically the Apache License, Version 2.0 (the "License") plus the
* "powered by wisemapping" text requirement on every single page;
* you may not use this file except in compliance with the License.
* You may obtain a copy of the license at
*
* http://www.wisemapping.org/license
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
mindplot.Workspace = new Class({
initialize: function(profile, screenManager, zoom) {
// Create a suitable container ...
$assert(screenManager, 'Div container can not be null');
2011-07-27 02:07:53 +08:00
this._zoom = zoom;
this._screenManager = screenManager;
this._screenWidth = profile.width;
this._screenHeight = profile.height;
// Initalize web2d workspace.
var workspace = this._createWorkspace(profile);
this._workspace = workspace;
var screenContainer = screenManager.getContainer();
// Fix the height of the container ....
screenContainer.style.height = this._screenHeight + "px";
// Append to the workspace...
workspace.addItAsChildTo(screenContainer);
this.setZoom(zoom, true);
// Register drag events ...
this._registerDragEvents();
this._eventsEnabled = true;
},
_updateScreenManager: function() {
var zoom = this._zoom;
this._screenManager.setScale(zoom);
var coordOriginX = -((this._screenWidth * this._zoom) / 2);
var coordOriginY = -((this._screenHeight * this._zoom) / 2);
this._screenManager.setOffset(coordOriginX, coordOriginY);
},
_createWorkspace: function(profile) {
// Initialize workspace ...
var coordOriginX = -(this._screenWidth / 2);
var coordOriginY = -(this._screenHeight / 2);
var workspaceProfile = {
width: this._screenWidth + "px",
height: this._screenHeight + "px",
coordSizeWidth:this._screenWidth,
coordSizeHeight:this._screenHeight,
coordOriginX:coordOriginX,
coordOriginY:coordOriginY,
fillColor:'transparent',
strokeWidth:0
};
web2d.peer.Toolkit.init();
return new web2d.Workspace(workspaceProfile);
},
appendChild: function(shape) {
if ($defined(shape.addToWorkspace)) {
2011-07-27 02:07:53 +08:00
shape.addToWorkspace(this);
} else {
this._workspace.appendChild(shape);
}
},
removeChild: function(shape) {
// Element is a node, not a web2d element?
if ($defined(shape.removeFromWorkspace)) {
2011-07-27 02:07:53 +08:00
shape.removeFromWorkspace(this);
} else {
this._workspace.removeChild(shape);
}
},
addEventListener: function(type, listener) {
this._workspace.addEventListener(type, listener);
},
removeEventListener: function(type, listener) {
this._workspace.removeEventListener(type, listener);
},
getSize: function() {
return this._workspace.getCoordSize();
},
setZoom: function(zoom, center) {
this._zoom = zoom;
var workspace = this._workspace;
// Update coord scale...
var coordWidth = zoom * this._screenWidth;
var coordHeight = zoom * this._screenHeight;
workspace.setCoordSize(coordWidth, coordHeight);
// Center topic....
var coordOriginX;
var coordOriginY;
if (center) {
coordOriginX = -(coordWidth / 2);
coordOriginY = -(coordHeight / 2);
} else {
var coordOrigin = workspace.getCoordOrigin();
coordOriginX = coordOrigin.x;
coordOriginY = coordOrigin.y;
}
2009-06-08 02:59:43 +08:00
2011-07-27 02:07:53 +08:00
workspace.setCoordOrigin(coordOriginX, coordOriginY);
// Update screen.
this._screenManager.setOffset(coordOriginX, coordOriginY);
this._screenManager.setScale(zoom);
},
getScreenManager: function() {
return this._screenManager;
},
enableWorkspaceEvents: function(value) {
this._eventsEnabled = value;
},
isWorkspaceEventsEnabled: function() {
return this._eventsEnabled;
},
dumpNativeChart: function() {
var workspace = this._workspace;
return workspace.dumpNativeChart();
},
_registerDragEvents: function() {
var workspace = this._workspace;
var screenManager = this._screenManager;
this._dragging = true;
var mWorkspace = this;
2011-07-28 01:53:32 +08:00
var mouseDownListener = function(event) {
if (!$defined(workspace.mouseMoveListener)) {
2011-07-27 02:07:53 +08:00
if (mWorkspace.isWorkspaceEventsEnabled()) {
mWorkspace.enableWorkspaceEvents(false);
2009-06-08 02:59:43 +08:00
2011-07-27 02:07:53 +08:00
var mouseDownPosition = screenManager.getWorkspaceMousePosition(event);
var originalCoordOrigin = workspace.getCoordOrigin();
2009-06-08 02:59:43 +08:00
2011-07-27 02:07:53 +08:00
workspace.mouseMoveListener = function(event) {
2009-06-08 02:59:43 +08:00
var currentMousePosition = screenManager.getWorkspaceMousePosition(event);
var offsetX = currentMousePosition.x - mouseDownPosition.x;
var coordOriginX = -offsetX + originalCoordOrigin.x;
var offsetY = currentMousePosition.y - mouseDownPosition.y;
var coordOriginY = -offsetY + originalCoordOrigin.y;
workspace.setCoordOrigin(coordOriginX, coordOriginY);
// Change cursor.
2011-07-27 02:07:53 +08:00
if (core.UserAgent.isMozillaFamily()) {
2009-06-08 02:59:43 +08:00
window.document.body.style.cursor = "-moz-grabbing";
2011-07-27 02:07:53 +08:00
} else {
2009-06-08 02:59:43 +08:00
window.document.body.style.cursor = "move";
}
2011-07-27 02:07:53 +08:00
event.preventDefault();
}.bindWithEvent(this);
screenManager.addEventListener('mousemove', workspace.mouseMoveListener);
// Register mouse up listeners ...
workspace.mouseUpListener = function(event) {
screenManager.removeEventListener('mousemove', workspace.mouseMoveListener);
screenManager.removeEventListener('mouseup', workspace.mouseUpListener);
workspace.mouseUpListener = null;
workspace.mouseMoveListener = null;
window.document.body.style.cursor = 'default';
// Update screen manager offset.
var coordOrigin = workspace.getCoordOrigin();
screenManager.setOffset(coordOrigin.x, coordOrigin.y);
mWorkspace.enableWorkspaceEvents(true);
},
screenManager.addEventListener('mouseup', workspace.mouseUpListener);
}
} else {
workspace.mouseUpListener();
2009-06-08 02:59:43 +08:00
}
2011-07-27 02:07:53 +08:00
};
screenManager.addEventListener('mousedown', mouseDownListener);
}
});
2009-06-08 02:59:43 +08:00