1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 #ifndef SD_SLIDESORTER_PAGE_OBJECT_LAYOUTER_HXX 25 #define SD_SLIDESORTER_PAGE_OBJECT_LAYOUTER_HXX 26 27 #include "SlideSorter.hxx" 28 #include "model/SlsSharedPageDescriptor.hxx" 29 #include "tools/gen.hxx" 30 #include <vcl/image.hxx> 31 32 namespace sd { namespace slidesorter { namespace view { 33 34 35 /** In contrast to the Layouter that places page objects in the view, the 36 PageObjectLayouter places the parts of individual page objects like page 37 number area, borders, preview. 38 */ 39 class PageObjectLayouter 40 { 41 public: 42 /** Create a new PageObjectLayouter object. 43 @param rPageObjectSize 44 In general either the width or the height will be 0 in order to 45 signal that this size component has to be calculated from the other. 46 This calculation will make the preview as large as possible. 47 @param nPageCount 48 The page count is used to determine how wide the page number 49 area has to be, how many digits to except for the largest page number. 50 */ 51 PageObjectLayouter( 52 const ::boost::shared_ptr<Theme>& rpTheme, 53 const Size& rPageObjectWindowSize, 54 const Size& rPreviewModelSize, 55 const SharedSdWindow& rpWindow, 56 const sal_Int32 nPageCount); 57 ~PageObjectLayouter(void); 58 59 enum Part { 60 // The focus indicator is painted outside the actual page object. 61 FocusIndicator, 62 // This is the outer bounding box that includes the preview, page 63 // number, title. 64 PageObject, 65 // Bounding box of the actual preview. 66 Preview, 67 // Bounding box of the mouse indicator indicator frame. 68 MouseOverIndicator, 69 // Bounding box of the page number. 70 PageNumber, 71 // Bounding box of the pane name. 72 Name, 73 // Indicator whether or not there is a slide transition associated 74 // with this slide. 75 TransitionEffectIndicator 76 }; 77 /** Two coordinate systems are supported. They differ only in 78 translation not in scale. Both relate to pixel values in the window. 79 A position in the model coordinate system does not change when the window content is 80 scrolled up or down. In the window coordinate system (relative 81 to the top left point of the window) scrolling leads to different values. 82 */ 83 enum CoordinateSystem { 84 WindowCoordinateSystem, 85 ModelCoordinateSystem 86 }; 87 88 /** Return the bounding box of the page object or one of its graphical 89 parts. 90 @param rWindow 91 This device is used to translate between model and window 92 coordinates. 93 @param rpPageDescriptor 94 The page for which to calculate the bounding box. This may be 95 NULL. When it is NULL then a generic bounding box is calculated 96 for the location (0,0). 97 @param ePart 98 The part of the page object for which to return the bounding 99 box. 100 @param eCoodinateSystem 101 The bounding box can be returned in model and in pixel 102 (window) coordinates. 103 */ 104 Rectangle GetBoundingBox ( 105 const model::SharedPageDescriptor& rpPageDescriptor, 106 const Part ePart, 107 const CoordinateSystem eCoordinateSystem); 108 Rectangle GetBoundingBox ( 109 const Point& rPageObjectLocation, 110 const Part ePart, 111 const CoordinateSystem eCoordinateSystem); 112 Size GetSize ( 113 const Part ePart, 114 const CoordinateSystem eCoordinateSystem); 115 116 Image GetTransitionEffectIcon (void) const; 117 118 private: 119 SharedSdWindow mpWindow; 120 Size maPageObjectSize; 121 double mnModelToWindowScale; 122 Rectangle maFocusIndicatorBoundingBox; 123 Rectangle maPageObjectBoundingBox; 124 Rectangle maPageNumberAreaBoundingBox; 125 Rectangle maPreviewBoundingBox; 126 Rectangle maTransitionEffectBoundingBox; 127 const Image maTransitionEffectIcon; 128 const ::boost::shared_ptr<Font> mpPageNumberFont; 129 130 Size GetPageNumberAreaSize (const int nPageCount); 131 Rectangle CalculatePreviewBoundingBox ( 132 Size& rPageObjectSize, 133 const Size& rPreviewModelSize, 134 const sal_Int32 nPageNumberAreaWidth, 135 const sal_Int32 nFocusIndicatorWidth); 136 }; 137 138 139 } } } // end of namespace ::sd::slidesorter::view 140 141 #endif 142