org.icepdf.ri.common.tools.TextSelectionPageHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of icepdf-viewer Show documentation
Show all versions of icepdf-viewer Show documentation
ICEpdf PDF Viewer Reference Implementation (RI)
/*
* Copyright 2006-2017 ICEsoft Technologies Canada Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an "AS
* IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
package org.icepdf.ri.common.tools;
import org.icepdf.core.pobjects.Page;
import org.icepdf.ri.common.views.AbstractPageViewComponent;
import org.icepdf.ri.common.views.DocumentViewController;
import org.icepdf.ri.common.views.DocumentViewModel;
import java.awt.*;
import java.awt.event.MouseEvent;
import java.awt.geom.AffineTransform;
import java.awt.geom.GeneralPath;
import java.awt.geom.NoninvertibleTransformException;
import java.util.ArrayList;
import java.util.logging.Level;
/**
* Handles Paint and mouse/keyboard logic around text selection and search
* highlighting. there is on text handler isntance of each pageComponent
* used to dispaly the document.
*
* The highlight colour by default is #FFF600 but can be set using color or
* hex values names using the system property "org.icepdf.core.views.page.text.highlightColor"
*
* The highlight colour by default is #FFF600 but can be set using color or
* hex values names using the system property "org.icepdf.core.views.page.text.selectionColor"
*
*
* @since 4.0
*/
public class TextSelectionPageHandler extends TextSelection
implements ToolHandler {
/**
* New Text selection handler. Make sure to correctly and and remove
* this mouse and text listeners.
*
* @param pageViewComponent page component that this handler is bound to.
* @param documentViewModel view model.
*/
public TextSelectionPageHandler(DocumentViewController documentViewController,
AbstractPageViewComponent pageViewComponent,
DocumentViewModel documentViewModel) {
super(documentViewController, pageViewComponent, documentViewModel);
}
public void setDocumentViewController(DocumentViewController documentViewController) {
this.documentViewController = documentViewController;
}
/**
* When mouse is double clicked we select the word the mouse if over. When
* the mouse is triple clicked we select the line of text that the mouse
* is over.
*/
public void mouseClicked(MouseEvent e) {
wordLineSelection(e.getClickCount(), e.getPoint(), pageViewComponent);
}
/**
* Invoked when a mouse button has been pressed on a component.
*/
public void mousePressed(MouseEvent e) {
lastMousePressedLocation = e.getPoint();
selectionStart(e.getPoint(), pageViewComponent, true);
}
/**
* Invoked when a mouse button has been released on a component.
*/
public void mouseReleased(MouseEvent e) {
selectionEnd(e.getPoint(), pageViewComponent);
}
/**
* Invoked when a mouse button is pressed on a component and then
* dragged. MOUSE_DRAGGED
events will continue to be
* delivered to the component where the drag originated until the
* mouse button is released (regardless of whether the mouse position
* is within the bounds of the component).
*
* Due to platform-dependent Drag&Drop implementations,
* MOUSE_DRAGGED
events may not be delivered during a native
* Drag&Drop operation.
*/
public void mouseDragged(MouseEvent e) {
Point point = e.getPoint();
updateSelectionSize(point.x, point.y, pageViewComponent);
boolean isMovingDown = true;
boolean isMovingRight = true;
if (lastMousePressedLocation != null) {
isMovingDown = lastMousePressedLocation.y <= e.getPoint().y;
isMovingRight = lastMousePressedLocation.x <= e.getPoint().x;
}
selection(e.getPoint(), pageViewComponent, isMovingDown, isMovingRight);
}
/**
* Invoked when the mouse enters a component.
*/
public void mouseEntered(MouseEvent e) {
}
/**
* Invoked when the mouse exits a component.
*/
public void mouseExited(MouseEvent e) {
}
public void setSelectionRectangle(Point cursorLocation, Rectangle selection) {
// rectangle select tool
setSelectionSize(selection, pageViewComponent);
}
/**
* Invoked when the mouse cursor has been moved onto a component
* but no buttons have been pushed.
*/
public void mouseMoved(MouseEvent e) {
// change state of mouse from pointer to text selection icon
selectionIcon(e.getPoint(), pageViewComponent);
}
public void installTool() {
}
public void uninstallTool() {
}
public void paintTool(Graphics g) {
if (enableMarginExclusionBorder && topMarginExclusion != null && bottomMarginExclusion != null) {
Page currentPage = pageViewComponent.getPage();
AffineTransform at = currentPage.getPageTransform(
documentViewModel.getPageBoundary(),
documentViewModel.getViewRotation(),
documentViewModel.getViewZoom());
((Graphics2D)g).transform(at);
g.setColor(Color.RED);
paintSelectionBox(g, topMarginExclusion.getBounds());
g.setColor(Color.BLUE);
paintSelectionBox(g, bottomMarginExclusion.getBounds());
}
}
/**
* Convert the shapes that make up the annotation to page space so that
* they will scale correctly at different zooms.
*
* @return transformed bBox.
*/
protected Rectangle convertToPageSpace(ArrayList bounds,
GeneralPath path) {
Page currentPage = pageViewComponent.getPage();
AffineTransform at = currentPage.getPageTransform(
documentViewModel.getPageBoundary(),
documentViewModel.getViewRotation(),
documentViewModel.getViewZoom());
try {
at = at.createInverse();
} catch (NoninvertibleTransformException e) {
logger.log(Level.FINE, "Error converting to page space.", e);
}
// convert the two points as well as the bbox.
Rectangle tBbox = at.createTransformedShape(path).getBounds();
// convert the points
Shape bound;
for (int i = 0; i < bounds.size(); i++) {
bound = bounds.get(i);
bound = at.createTransformedShape(bound);
bounds.set(i, bound);
// bound.setRect(tBound.getX(), tBound.getY(),
// tBound.getWidth(), tBound.getHeight());
}
path.transform(at);
return tBbox;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy