8005405: [macosx] Drag and Drop: wrong animation when dropped outside any drop target

Changed the calculation of the drag image offset

Reviewed-by: serb, kizune
This commit is contained in:
Petr Pchelko 2013-02-04 13:54:53 +00:00
parent 018fbffe54
commit ab34438938
2 changed files with 20 additions and 39 deletions

View File

@ -88,40 +88,25 @@ public final class CDragSourceContextPeer extends SunDragSourceContextPeer {
DragGestureEvent trigger = getTrigger(); DragGestureEvent trigger = getTrigger();
InputEvent triggerEvent = trigger.getTriggerEvent(); InputEvent triggerEvent = trigger.getTriggerEvent();
Point dragOrigin = trigger.getDragOrigin(); Point dragOrigin = new Point(trigger.getDragOrigin());
int extModifiers = (triggerEvent.getModifiers() | triggerEvent.getModifiersEx()); int extModifiers = (triggerEvent.getModifiers() | triggerEvent.getModifiersEx());
long timestamp = triggerEvent.getWhen(); long timestamp = triggerEvent.getWhen();
int clickCount = ((triggerEvent instanceof MouseEvent) ? (((MouseEvent) triggerEvent).getClickCount()) : 1); int clickCount = ((triggerEvent instanceof MouseEvent) ? (((MouseEvent) triggerEvent).getClickCount()) : 1);
// Get drag source component and its peer:
Component component = trigger.getComponent(); Component component = trigger.getComponent();
Point componentOffset = new Point(); // For a lightweight component traverse up the hierarchy to the root
ComponentPeer peer = component.getPeer(); Point loc = component.getLocation();
Component rootComponent = component;
// For a lightweight component traverse up the hierarchy to the first heavyweight while (!(rootComponent instanceof Window)) {
// which will be used as the ComponentModel for the native drag source. dragOrigin.translate(loc.x, loc.y);
if (component.isLightweight()) { rootComponent = rootComponent.getParent();
Point loc = component.getLocation(); loc = rootComponent.getLocation();
componentOffset.translate(loc.x, loc.y);
for (Component parent = component.getParent(); parent != null; parent = parent.getParent()) {
if (parent.isLightweight() == false) {
peer = parent.getPeer();
break;
}
loc = parent.getLocation();
componentOffset.translate(loc.x, loc.y);
}
} }
// Make sure the drop target is a ComponentModel: //It sure will be LWComponentPeer instance as rootComponent is a Window
if (!(peer instanceof LWComponentPeer)) LWComponentPeer peer = (LWComponentPeer)rootComponent.getPeer();
throw new IllegalArgumentException("DragSource's peer must be a ComponentModel."); //Get a pointer to a native window
CPlatformWindow platformWindow = (CPlatformWindow) peer.getPlatformWindow();
// Get model pointer (CButton.m and such) and its native peer:
LWComponentPeer model = (LWComponentPeer) peer;
CPlatformWindow platformWindow = (CPlatformWindow) model.getPlatformWindow();
long nativeWindowPtr = platformWindow.getNSWindowPtr(); long nativeWindowPtr = platformWindow.getNSWindowPtr();
// Get drag cursor: // Get drag cursor:
@ -155,7 +140,7 @@ public final class CDragSourceContextPeer extends SunDragSourceContextPeer {
try { try {
// Create native dragging source: // Create native dragging source:
final long nativeDragSource = createNativeDragSource(component, peer, nativeWindowPtr, transferable, triggerEvent, final long nativeDragSource = createNativeDragSource(component, peer, nativeWindowPtr, transferable, triggerEvent,
(int) (dragOrigin.getX() + componentOffset.x), (int) (dragOrigin.getY() + componentOffset.y), extModifiers, (int) (dragOrigin.getX()), (int) (dragOrigin.getY()), extModifiers,
clickCount, timestamp, cursor, fDragCImage, dragImageOffset.x, dragImageOffset.y, clickCount, timestamp, cursor, fDragCImage, dragImageOffset.x, dragImageOffset.y,
getDragSourceContext().getSourceActions(), formats, formatMap); getDragSourceContext().getSourceActions(), formats, formatMap);
@ -165,8 +150,8 @@ public final class CDragSourceContextPeer extends SunDragSourceContextPeer {
setNativeContext(nativeDragSource); setNativeContext(nativeDragSource);
CCursorManager.getInstance().startDrag( CCursorManager.getInstance().startDrag(
(int) (dragOrigin.getX() + componentOffset.x), (int) (dragOrigin.getX()),
(int) (dragOrigin.getY() + componentOffset.y)); (int) (dragOrigin.getY()));
} }
catch (Exception e) { catch (Exception e) {

View File

@ -443,9 +443,9 @@ static BOOL sNeedsEnter;
NSGraphicsContext* graphicsContext = [NSGraphicsContext graphicsContextWithWindow:window]; NSGraphicsContext* graphicsContext = [NSGraphicsContext graphicsContextWithWindow:window];
// Convert mouse coordinates to NS: // Convert mouse coordinates to NS:
NSPoint location = NSMakePoint(fDragPos.x, fDragPos.y); NSPoint eventLocation = [fView convertPoint:NSMakePoint(fDragPos.x, fDragPos.y) toView:nil];
NSPoint eventLocation = [fView convertPoint:location toView:nil]; eventLocation.y = [[fView window] frame].size.height - eventLocation.y;
// Convert fTriggerEventTimeStamp to NS - AWTEvent.h defines UTC(nsEvent) as ((jlong)[event timestamp] * 1000): // Convert fTriggerEventTimeStamp to NS - AWTEvent.h defines UTC(nsEvent) as ((jlong)[event timestamp] * 1000):
NSTimeInterval timeStamp = fTriggerEventTimeStamp / 1000; NSTimeInterval timeStamp = fTriggerEventTimeStamp / 1000;
@ -497,12 +497,9 @@ static BOOL sNeedsEnter;
NSImage* dragImage = fDragImage; NSImage* dragImage = fDragImage;
// Get drag origin and offset: // Get drag origin and offset:
NSPoint dragOrigin; NSPoint dragOrigin = [dragEvent locationInWindow];
dragOrigin.x = fDragPos.x;
dragOrigin.y = fDragPos.y;
dragOrigin = [view convertPoint:[dragEvent locationInWindow] fromView:nil];
dragOrigin.x += fDragImageOffset.x; dragOrigin.x += fDragImageOffset.x;
dragOrigin.y += [dragImage size].height + fDragImageOffset.y; dragOrigin.y -= fDragImageOffset.y + [dragImage size].height;
// Drag offset values don't seem to matter: // Drag offset values don't seem to matter:
NSSize dragOffset = NSMakeSize(0, 0); NSSize dragOffset = NSMakeSize(0, 0);
@ -516,7 +513,6 @@ static BOOL sNeedsEnter;
DLog5(@" - drag image: %f, %f (%f x %f)", fDragImageOffset.x, fDragImageOffset.y, [dragImage size].width, [dragImage size].height); DLog5(@" - drag image: %f, %f (%f x %f)", fDragImageOffset.x, fDragImageOffset.y, [dragImage size].width, [dragImage size].height);
DLog3(@" - event point (window) %f, %f", [dragEvent locationInWindow].x, [dragEvent locationInWindow].y); DLog3(@" - event point (window) %f, %f", [dragEvent locationInWindow].x, [dragEvent locationInWindow].y);
DLog3(@" - drag point (view) %f, %f", dragOrigin.x, dragOrigin.y); DLog3(@" - drag point (view) %f, %f", dragOrigin.x, dragOrigin.y);
// Set up the fDragKeyModifier, so we know if the operation has changed // Set up the fDragKeyModifier, so we know if the operation has changed
// Set up the fDragMouseModifier, so we can |= it later (since CoreDrag doesn't tell us mouse states during a drag) // Set up the fDragMouseModifier, so we can |= it later (since CoreDrag doesn't tell us mouse states during a drag)
fDragKeyModifiers = [DnDUtilities extractJavaExtKeyModifiersFromJavaExtModifiers:fModifiers]; fDragKeyModifiers = [DnDUtilities extractJavaExtKeyModifiersFromJavaExtModifiers:fModifiers];