blob: f09ca3b2c41a7b1b8d32e2e47cdf642616d0cc56 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2014, 2020 Dirk Fauth and others.
*
* This program and the accompanying materials are made
* available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Dirk Fauth <dirk.fauth@googlemail.com> - initial API and implementation
*******************************************************************************/
package org.eclipse.nebula.widgets.nattable.layer.event;
import java.util.Collection;
import org.eclipse.nebula.widgets.nattable.coordinate.PositionUtil;
import org.eclipse.nebula.widgets.nattable.layer.ILayer;
import org.eclipse.nebula.widgets.nattable.layer.IUniqueIndexLayer;
/**
* Specialization of the RowVisualChangeEvent. The only difference is the
* handling of this type of event in the NatTable event handling. While the
* RowVisualChangeEvent causes a whole redraw operation of the visible part
* (which is necessary to update everything if a data value has change, for
* example important for conditional styling), this event only forces to redraw
* the specified row itself.
*/
public class RowVisualUpdateEvent extends RowVisualChangeEvent {
/**
* Create a new RowVisualUpdateEvent based on the given information.
*
* @param layer
* The layer to which the given row position belongs.
* @param rowPosition
* The row position of the row that needs to be redrawn.
*/
public RowVisualUpdateEvent(ILayer layer, int rowPosition) {
super(layer, rowPosition);
}
/**
* Create a new RowVisualUpdateEvent based on the given information.
*
* @param layer
* The layer to which the given column and row position belong.
* @param rowPositions
* The row positions of the rows that need to be redrawn.
*/
public RowVisualUpdateEvent(IUniqueIndexLayer layer, int[] rowPositions) {
super(layer, PositionUtil.getRanges(rowPositions));
}
/**
* Create a new RowVisualUpdateEvent based on the given information.
*
* @param layer
* The layer to which the given row positions belong.
* @param rowPositions
* The row positions of the rows that need to be redrawn.
*/
public RowVisualUpdateEvent(IUniqueIndexLayer layer,
Collection<Integer> rowPositions) {
super(layer, PositionUtil.getRanges(rowPositions));
}
/**
* Create a new RowVisualUpdateEvent out of the given event. Used internally
* for cloning purposes.
*
* @param event
* The event to create the clone from.
*/
protected RowVisualUpdateEvent(RowVisualUpdateEvent event) {
super(event);
}
@Override
public RowVisualUpdateEvent cloneEvent() {
return new RowVisualUpdateEvent(this);
}
}