package com.smartgwt.sample.showcase.client.basics.interaction;
import com.smartgwt.client.types.Alignment;
import com.smartgwt.client.types.Overflow;
import com.smartgwt.client.util.EventHandler;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.Label;
import com.smartgwt.client.widgets.events.*;
import com.smartgwt.sample.showcase.client.PanelFactory;
import com.smartgwt.sample.showcase.client.ShowcasePanel;
public class MouseEventsSample extends ShowcasePanel {
private static final String DESCRIPTION = "<p>Mouse over the blue square to see the color respond to your position. Click and hold to see a fade. " +
"If you have a mousewheel, roll up and down to change size.<p><p>Smart GWT components support the standard " +
"mouse events in addition to custom events like \"mouseStillDown\".</p>";
public static class Factory implements PanelFactory {
private String id;
public Canvas create() {
MouseEventsSample panel = new MouseEventsSample();
id = panel.getID();
return panel;
}
public String getID() {
return id;
}
public String getDescription() {
return DESCRIPTION;
}
}
public Canvas getViewPanel() {
Canvas canvas = new Canvas();
final TrackerLabel eventTrackerLabel = new TrackerLabel();
eventTrackerLabel.setContents("<nobr>Last event: (mouse over the canvas below...)</nobr>");
eventTrackerLabel.setHeight(20);
final MouserLabel label = new MouserLabel();
label.setContents("<b>Mouse Me</b>");
label.setAlign(Alignment.CENTER);
label.setOverflow(Overflow.HIDDEN);
label.setShowEdges(true);
label.setBackgroundColor("lightblue");
label.setWidth(200);
label.setHeight(200);
label.setTop(40);
label.addMouseWheelHandler(new MouseWheelHandler() {
public void onMouseWheel(MouseWheelEvent event) {
int wheelDelta = EventHandler.getWheelDelta();
int newSize = label.getWidth() + wheelDelta * label.getZoomMultiplier();
if (newSize < label.getMinSize()) {
newSize = label.getMinSize();
} else if (newSize > label.getMaxSize()) {
newSize = label.getMaxSize();
}
label.setWidth(newSize);
label.setHeight(newSize);
eventTrackerLabel.setLastEvent("mouseWheel", label);
}
});
label.addMouseStillDownHandler(new MouseStillDownHandler() {
public void onMouseStillDown(MouseStillDownEvent event) {
Integer opacity = label.getOpacity();
if (opacity == null) opacity = 100;
label.setOpacity(Math.max(0, opacity - 5));
eventTrackerLabel.setLastEvent("mouseStillDown", label);
}
});
label.addMouseUpHandler(new MouseUpHandler() {
public void onMouseUp(MouseUpEvent event) {
label.setOpacity(100);
eventTrackerLabel.setLastEvent("mouseUp", label);
}
});
label.addMouseMoveHandler(new MouseMoveHandler() {
public void onMouseMove(MouseMoveEvent event) {
//scale to 1
float xScale = (label.getOffsetX() * 1f) / label.getWidth();
float yScale = (label.getOffsetY() * 1f) / label.getHeight();
// increasing red intensity on the x axis, green on the y axis. Blue stays at zero.
label.setBackgroundColor("rgb(0," + Math.round(255 * xScale) + "," + Math.round(255 * yScale) + ")");
eventTrackerLabel.setLastEvent("mouseMove", label);
}
});
label.addMouseOutHandler(new MouseOutHandler() {
public void onMouseOut(MouseOutEvent event) {
//restore settings
label.setBackgroundColor("lightblue");
label.setOpacity(100);
eventTrackerLabel.setLastEvent("mouseOut", label);
}
});
canvas.addChild(eventTrackerLabel);
canvas.addChild(label);
return canvas;
}
public String getIntro() {
return DESCRIPTION;
}
class TrackerLabel extends Label {
public void setLastEvent(String eventName, MouserLabel label) {
int localX = label.getOffsetX();
int localY = label.getOffsetY();
setContents("<nobr>Last event: <b>" + eventName + "</b> (" + localX + ", " + localY + ")</nobr>");
}
}
class MouserLabel extends Label {
private int minSize = 40;
private int maxSize = 400;
private int zoomMultiplier = 15;
public int getMinSize() {
return minSize;
}
public void setMinSize(int minSize) {
this.minSize = minSize;
}
public int getMaxSize() {
return maxSize;
}
public void setMaxSize(int maxSize) {
this.maxSize = maxSize;
}
public int getZoomMultiplier() {
return zoomMultiplier;
}
public void setZoomMultiplier(int zoomMultiplier) {
this.zoomMultiplier = zoomMultiplier;
}
}
}