All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.swt.dnd.TableDragSourceEffect Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2007, 2012 IBM Corporation and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
package org.eclipse.swt.dnd;

import org.eclipse.swt.*;
import org.eclipse.swt.graphics.*;
import org.eclipse.swt.internal.cocoa.*;
import org.eclipse.swt.widgets.*;

/**
 * This class provides default implementations to display a source image
 * when a drag is initiated from a Table.
 *
 * 

Classes that wish to provide their own source image for a Table can * extend the TableDragSourceEffect class, override the * TableDragSourceEffect.dragStart method and set the field * DragSourceEvent.image with their own image.

* * Subclasses that override any methods of this class must call the corresponding * super method to get the default drag source effect implementation. * * @see DragSourceEffect * @see DragSourceEvent * @see Sample code and further information * * @since 3.3 */ public class TableDragSourceEffect extends DragSourceEffect { Image dragSourceImage = null; /** * Creates a new TableDragSourceEffect to handle drag effect * from the specified Table. * * @param table the Table that the user clicks on to initiate the drag */ public TableDragSourceEffect(Table table) { super(table); } /** * This implementation of dragFinished disposes the image * that was created in TableDragSourceEffect.dragStart. * * Subclasses that override this method should call super.dragFinished(event) * to dispose the image in the default implementation. * * @param event the information associated with the drag finished event */ @Override public void dragFinished(DragSourceEvent event) { if (dragSourceImage != null) dragSourceImage.dispose(); dragSourceImage = null; } /** * This implementation of dragStart will create a default * image that will be used during the drag. The image should be disposed * when the drag is completed in the TableDragSourceEffect.dragFinished * method. * * Subclasses that override this method should call super.dragStart(event) * to use the image from the default implementation. * * @param event the information associated with the drag start event */ @Override public void dragStart(DragSourceEvent event) { event.image = getDragSourceImage(event); } Image getDragSourceImage(DragSourceEvent event) { if (dragSourceImage != null) dragSourceImage.dispose(); dragSourceImage = null; NSPoint point = new NSPoint(); long /*int*/ ptr = OS.malloc(NSPoint.sizeof); OS.memmove(ptr, point, NSPoint.sizeof); NSEvent nsEvent = NSApplication.sharedApplication().currentEvent(); NSTableView widget = (NSTableView)control.view; NSImage nsImage = widget.dragImageForRowsWithIndexes(widget.selectedRowIndexes(), widget.tableColumns(), nsEvent, ptr); OS.memmove(point, ptr, NSPoint.sizeof); OS.free(ptr); if (nsImage == null) return null; //TODO: Image representation wrong??? Image image = Image.cocoa_new(control.getDisplay(), SWT.BITMAP, nsImage); dragSourceImage = image; nsImage.retain(); event.offsetX = (int)point.x; event.offsetY = (int)point.y; return image; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy