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

org.icepdf.ri.common.tools.TextSelectionPageHandler Maven / Gradle / Ivy

There is a newer version: 6.2.2
Show newest version
/*
 * 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