package com.smartgwt.sample.showcase.client.basics.components;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.Img;
import com.smartgwt.client.widgets.events.ClickEvent;
import com.smartgwt.client.widgets.events.ClickHandler;
import com.smartgwt.client.widgets.events.MouseStillDownEvent;
import com.smartgwt.client.widgets.events.MouseStillDownHandler;
import com.smartgwt.client.widgets.layout.HLayout;
import com.smartgwt.client.widgets.layout.VLayout;
import com.smartgwt.sample.showcase.client.PanelFactory;
import com.smartgwt.sample.showcase.client.ShowcasePanel;
public class MoveSample extends ShowcasePanel {
private static final String DESCRIPTION = "Click and hold the arrow to move the image. Click on the solid circle to return to the starting position.";
public static class Factory implements PanelFactory {
private String id;
public Canvas create() {
MoveSample panel = new MoveSample();
id = panel.getID();
return panel;
}
public String getID() {
return id;
}
public String getDescription() {
return DESCRIPTION;
}
}
public Canvas getViewPanel() {
VLayout layout = new VLayout();
layout.setMembersMargin(10);
layout.setAutoHeight();
HLayout hLayout = new HLayout();
final Img vanImg = new Img("crystal/128/apps/virussafe.png", 96, 96);
vanImg.setCanDragReposition(true);
vanImg.setTop(0);
vanImg.setLeft(50);
Img resetImg = new Img("icons/48/reset.png", 48, 48);
resetImg.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
vanImg.moveTo(50, 0);
}
});
Img moveImg = new Img("icons/48/downright.png", 48, 48);
moveImg.setShowRollOver(true);
moveImg.addMouseStillDownHandler(new MouseStillDownHandler() {
public void onMouseStillDown(MouseStillDownEvent event) {
vanImg.moveBy(20, 20);
}
});
hLayout.addMember(resetImg);
hLayout.addMember(moveImg);
//were positioning the vanImg using absolute poitioning relative to its containing canvas
Canvas vanCanvas = new Canvas();
vanCanvas.addChild(vanImg);
layout.addMember(hLayout);
layout.addMember(vanCanvas);
return layout;
}
public String getIntro() {
return DESCRIPTION;
}
}