/******************************************************************************* * Copyright (c) 2012 Original authors 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: * Original authors and others - initial API and implementation ******************************************************************************/ package org.eclipse.nebula.widgets.nattable.selection.action; import org.eclipse.nebula.widgets.nattable.NatTable; import org.eclipse.nebula.widgets.nattable.selection.command.ClearAllSelectionsCommand; import org.eclipse.nebula.widgets.nattable.selection.config.RowOnlySelectionBindings; import org.eclipse.nebula.widgets.nattable.ui.action.IDragMode; import org.eclipse.swt.events.MouseEvent; /** * Selects the entire row when the mouse is dragged on the body. Only a * <i>single</i> row is selected at a given time. This is the row the mouse is * over. * * @see RowOnlySelectionBindings */ public class SingleRowSelectionDragMode extends RowSelectionDragMode implements IDragMode { @Override public void mouseMove(NatTable natTable, MouseEvent event) { natTable.doCommand(new ClearAllSelectionsCommand()); if (event.x > natTable.getWidth()) { return; } int selectedColumnPosition = natTable.getColumnPositionByX(event.x); int selectedRowPosition = natTable.getRowPositionByY(event.y); if (selectedColumnPosition > -1 && selectedRowPosition > -1) { fireSelectionCommand(natTable, selectedColumnPosition, selectedRowPosition, false, false); } } }