因此,我很难解释我的问题,我希望这很清楚。请告诉我是否可以说得更好一点!
我有一个使用gwt-dnd拖放小部件的GWT Web应用程序。我具有扩展AbsolutePanel并在其上显示标题和数字的Notecard对象(如3x5便笺卡)。
我有一个垂直的InsertPanel(gwt FlowPanel),Notecard对象插入其中,一个在下一个之上(这里的顺序很重要)。假设InsertPanel中包含5张记事卡,它们全部垂直对齐。如果我选择其中一个,将其移动到InsertPanel中的另一个索引,然后将其放下,则Notecard的主体将被放置在应有的位置,但是标题和编号与Notecard的主体分开并一直推到InsertPanel的顶部。如果我继续移动记事本,则所有记事本主体均按计划运行,但是所有标题和编号都在InsertPanel的顶部彼此堆叠。
我缺少将Notecard小部件组件“粘合”在一起的东西吗?我尝试让Notecard扩展Composite而不是AbsolutePanel,但是我得到了相同的行为。
作为参考,我在下面附加了涉及的Notecard类:
Notecard.java:
public class Notecard extends AbsolutePanel implements HasAllMouseHandlers {
private Long ID;
private String storyTitle;
private int points;
private Button dragHandleButton;
private AbstractProject project;
/*
* Constructors
*/
public Notecard( Long Id, String ttl, int pts ) {
this.ID = Id;
this.storyTitle = ttl;
this.points = pts;
setStyleName("Notecard-Wrapper");
setSize("100px", "60px");
Label titleLabel = new Label(storyTitle);
titleLabel.setStyleName("Notecard-TitleLabel");
add(titleLabel, 0, 0);
titleLabel.setSize("96px", "28px");
Label pointsLabel = new Label("" + points);
pointsLabel.setStyleName("Notecard-PointsLabel");
add(pointsLabel, 0, 35);
pointsLabel.setSize("100px", "20px");
dragHandleButton = new Button("");
dragHandleButton.setText("");
dragHandleButton.setStyleName("dragHandleButton");
add(dragHandleButton, 0, 0);
dragHandleButton.setSize("100px", "60px");
Button addTaskButton = new Button("+");
addTaskButton.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
popupAddTaskPopup();
}
});
addTaskButton.setStyleName("Notecard-AddTaskButton");
addTaskButton.setText("+");
add(addTaskButton, 0, 40);
addTaskButton.setSize("20px", "20px");
}
public void popupAddTaskPopup() {
project.popupAddTaskPopupPanel( ID );
}
/*
* GETTERS & SETTERS
*/
public String getStoryTitle() {
return storyTitle;
}
public void setStoryTitle(String title) {
this.storyTitle = title;
}
public int getPoints() {
return points;
}
public void setPoints(int points) {
this.points = points;
}
public Long getID() {
return ID;
}
public Button getDragHandle() {
return dragHandleButton;
}
/*
* Implementation for HasAllMouseHandlers
*/
@Override
public HandlerRegistration addMouseDownHandler(MouseDownHandler handler) {
return dragHandleButton.addMouseDownHandler(handler);
}
@Override
public HandlerRegistration addMouseUpHandler(MouseUpHandler handler) {
return dragHandleButton.addMouseUpHandler(handler);
}
@Override
public HandlerRegistration addMouseOutHandler(MouseOutHandler handler) {
return dragHandleButton.addMouseOutHandler(handler);
}
@Override
public HandlerRegistration addMouseOverHandler(MouseOverHandler handler) {
return dragHandleButton.addMouseOverHandler(handler);
}
@Override
public HandlerRegistration addMouseMoveHandler(MouseMoveHandler handler) {
return dragHandleButton.addMouseMoveHandler(handler);
}
@Override
public HandlerRegistration addMouseWheelHandler(MouseWheelHandler handler) {
return dragHandleButton.addMouseWheelHandler(handler);
}
我还使用了实现了onDrop()事件的拖放控制器。但是它只对onDrop()使用AbstractInsertPanelDropController实现,然后为持久性机制添加了一些功能。
最佳答案
我解决了这个问题。事实证明,它根本不是GWT或拖放对象。这是一个CSS问题。您会注意到,我的Notecard类是由AbsolutePanel组成的,然后其子元素都被完全放置。对于小部件的原始图形,GWT足够聪明,可以将子元素放置在Notecard的包装(AbsolutePanel)的内部。但是,将Notecard拖放时,它只是标准js,而不是GWT。因此,子窗口小部件的CSS属性表示:
/* CSS for child widgets */
position: absolute;
left: 0;
top: 0;
不再相对于Notecard包装器,而是相对于RootPanel。我所做的就是在Notecard包装器中添加CSS样式,以确保其子类相对于它:
/* CSS for Notecard-Wrapper */
position: relative;
然后一切都很好。
我使用Firebug for Firefox来解决这个问题,然后Google来解决CSS问题。