xref: /aoo41x/main/svx/inc/svx/xdash.hxx (revision 3334a7e6)
1*3334a7e6SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*3334a7e6SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*3334a7e6SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*3334a7e6SAndrew Rist  * distributed with this work for additional information
6*3334a7e6SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*3334a7e6SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*3334a7e6SAndrew Rist  * "License"); you may not use this file except in compliance
9*3334a7e6SAndrew Rist  * with the License.  You may obtain a copy of the License at
10*3334a7e6SAndrew Rist  *
11*3334a7e6SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*3334a7e6SAndrew Rist  *
13*3334a7e6SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*3334a7e6SAndrew Rist  * software distributed under the License is distributed on an
15*3334a7e6SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*3334a7e6SAndrew Rist  * KIND, either express or implied.  See the License for the
17*3334a7e6SAndrew Rist  * specific language governing permissions and limitations
18*3334a7e6SAndrew Rist  * under the License.
19*3334a7e6SAndrew Rist  *
20*3334a7e6SAndrew Rist  *************************************************************/
21*3334a7e6SAndrew Rist 
22*3334a7e6SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir #ifndef _SVX_XDASH_HXX
25cdf0e10cSrcweir #define _SVX_XDASH_HXX
26cdf0e10cSrcweir 
27cdf0e10cSrcweir //-------------
28cdf0e10cSrcweir // class XDash
29cdf0e10cSrcweir //-------------
30cdf0e10cSrcweir 
31cdf0e10cSrcweir #include <svx/xenum.hxx>
32cdf0e10cSrcweir #include "svx/svxdllapi.h"
33cdf0e10cSrcweir 
34cdf0e10cSrcweir #include <vector>
35cdf0e10cSrcweir 
36cdf0e10cSrcweir class SVX_DLLPUBLIC XDash
37cdf0e10cSrcweir {
38cdf0e10cSrcweir protected:
39cdf0e10cSrcweir 	XDashStyle  eDash;
40cdf0e10cSrcweir 	sal_uInt16      nDots;
41cdf0e10cSrcweir 	sal_uIntPtr       nDotLen;
42cdf0e10cSrcweir 	sal_uInt16      nDashes;
43cdf0e10cSrcweir 	sal_uIntPtr       nDashLen;
44cdf0e10cSrcweir 	sal_uIntPtr       nDistance;
45cdf0e10cSrcweir 
46cdf0e10cSrcweir public:
47cdf0e10cSrcweir 		  XDash(XDashStyle eDash = XDASH_RECT,
48cdf0e10cSrcweir 				sal_uInt16 nDots = 1, sal_uIntPtr nDotLen = 20,
49cdf0e10cSrcweir 				sal_uInt16 nDashes = 1, sal_uIntPtr nDashLen = 20, sal_uIntPtr nDistance = 20);
50cdf0e10cSrcweir 
51cdf0e10cSrcweir 	bool operator==(const XDash& rDash) const;
52cdf0e10cSrcweir 
SetDashStyle(XDashStyle eNewStyle)53cdf0e10cSrcweir 	void SetDashStyle(XDashStyle eNewStyle) { eDash = eNewStyle; }
SetDots(sal_uInt16 nNewDots)54cdf0e10cSrcweir 	void SetDots(sal_uInt16 nNewDots)           { nDots = nNewDots; }
SetDotLen(sal_uIntPtr nNewDotLen)55cdf0e10cSrcweir 	void SetDotLen(sal_uIntPtr nNewDotLen)        { nDotLen = nNewDotLen; }
SetDashes(sal_uInt16 nNewDashes)56cdf0e10cSrcweir 	void SetDashes(sal_uInt16 nNewDashes)       { nDashes = nNewDashes; }
SetDashLen(sal_uIntPtr nNewDashLen)57cdf0e10cSrcweir 	void SetDashLen(sal_uIntPtr nNewDashLen)      { nDashLen = nNewDashLen; }
SetDistance(sal_uIntPtr nNewDistance)58cdf0e10cSrcweir 	void SetDistance(sal_uIntPtr nNewDistance)    { nDistance = nNewDistance; }
59cdf0e10cSrcweir 
GetDashStyle() const60cdf0e10cSrcweir 	XDashStyle  GetDashStyle() const        { return eDash; }
GetDots() const61cdf0e10cSrcweir 	sal_uInt16      GetDots() const             { return nDots; }
GetDotLen() const62cdf0e10cSrcweir 	sal_uIntPtr       GetDotLen() const           { return nDotLen; }
GetDashes() const63cdf0e10cSrcweir 	sal_uInt16      GetDashes() const           { return nDashes; }
GetDashLen() const64cdf0e10cSrcweir 	sal_uIntPtr       GetDashLen() const          { return nDashLen; }
GetDistance() const65cdf0e10cSrcweir 	sal_uIntPtr       GetDistance() const         { return nDistance; }
66cdf0e10cSrcweir 
67cdf0e10cSrcweir 	// XDash is translated into an array of doubles which describe the lengths of the
68cdf0e10cSrcweir 	// dashes, dots and empty passages. It returns the complete length of the full DashDot
69cdf0e10cSrcweir 	// sequence and fills the given vetor of doubles accordingly (also resizing, so deleting it).
70cdf0e10cSrcweir 	double CreateDotDashArray(::std::vector< double >& rDotDashArray, double fLineWidth) const;
71cdf0e10cSrcweir };
72cdf0e10cSrcweir 
73cdf0e10cSrcweir #endif
74