org.eclipse.swt.dnd.TableDragSourceEffect Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of org.eclipse.swt.gtk.linux.ppc64le Show documentation
Show all versions of org.eclipse.swt.gtk.linux.ppc64le Show documentation
Standard Widget Toolkit for GTK on ppc64le
/*******************************************************************************
* Copyright (c) 2000, 2018 IBM Corporation and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* 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.cairo.*;
import org.eclipse.swt.internal.gtk.*;
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;
Table table = (Table) control;
//TEMPORARY CODE
if (table.isListening(SWT.EraseItem) || table.isListening (SWT.PaintItem)) return null;
/*
* Bug in GTK. gtk_tree_selection_get_selected_rows() segmentation faults
* in versions smaller than 2.2.4 if the model is NULL. The fix is
* to give a valid pointer instead.
*/
long handle = table.handle;
long selection = GTK.gtk_tree_view_get_selection (handle);
long [] model = null;
long list = GTK.gtk_tree_selection_get_selected_rows (selection, model);
if (list == 0) return null;
int count = Math.min(10, OS.g_list_length (list));
long originalList = list;
Display display = table.getDisplay();
if (count == 1) {
long path = OS.g_list_nth_data (list, 0);
long icon = GTK.gtk_tree_view_create_row_drag_icon (handle, path);
dragSourceImage = Image.gtk_new (display, SWT.ICON, icon, 0);
GTK.gtk_tree_path_free (path);
} else {
int width = 0, height = 0;
int[] w = new int[1], h = new int[1];
int[] yy = new int[count], hh = new int[count];
long [] icons = new long [count];
GdkRectangle rect = new GdkRectangle ();
for (int i=0; i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy