2010-10-14 08:27:31 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
re-base on ALv2 code. Includes (at least) relevant parts of:
linecap: Reintegrating finished LineCap feature
Patch contributed by Regina Henschel
http://svn.apache.org/viewvc?view=revision&revision=1232507
Patches contributed by Sven Jacobi
impress212: #i81610# fixed animation export
http://svn.apache.org/viewvc?view=revision&revision=1167620
impress212: drawinglayer gbuild environment changes
http://svn.apache.org/viewvc?view=revision&revision=1167627
http://svn.apache.org/viewvc?view=revision&revision=1167628
impress212: DffPropSet -> minor code improvements, removing table
http://svn.apache.org/viewvc?view=revision&revision=1167634
impress212: #158494# fixed excel import (text rotation)
http://svn.apache.org/viewvc?view=revision&revision=1167638
Patches contributed by Armin Le Grand
Svg: Reintegrated Svg replacement from /branches/alg/svgreplavement
http://svn.apache.org/viewvc?view=revision&revision=1220836
#118728# changed indentifying definitions for Svg file detection
http://svn.apache.org/viewvc?view=revision&revision=1229961
#118838# LineGeometry creation for complicated cases optimized to
create single Polygons
http://svn.apache.org/viewvc?view=revision&revision=1236232
#119176# corrected file type detection for SVG for svg files
without xml header
http://svn.apache.org/viewvc?view=revision&revision=1309445
#118728# Extended Svg file detection
http://svn.apache.org/viewvc?view=revision&revision=1230531
#118529# solve break converters and convert commands for OLEs and images
http://svn.apache.org/viewvc?view=revision&revision=1186168
svg: added WaE changes from branch svgreplacement to trunc
http://svn.apache.org/viewvc?view=revision&revision=1222974
svg: corrected missing member initialization
http://svn.apache.org/viewvc?view=revision&revision=1226134
fix for #118525#: Using primitives for chart sub-geometry visualisation
http://svn.apache.org/viewvc?view=revision&revision=1226879
#118898# Adapted ImpGraphic::ImplGetBitmap to correctly convert
metafiles to bitmapEx ...
http://svn.apache.org/viewvc?view=revision&revision=1293316
fix for #118525#: removed no longer used variable maOriginalMapMode, one
more exception eliminated
http://svn.apache.org/viewvc?view=revision&revision=1227097
#16758# Added buffering to the VDev usages of the VclProcessor2D derivates...
http://svn.apache.org/viewvc?view=revision&revision=1229521
#116758# Secured VDev buffer device to Vcl deinit
http://svn.apache.org/viewvc?view=revision&revision=1230574
#116758# added remembering allocated VDevs for VDevBuffer to be able to also
delete these when vcl goes down; it should never happen, but You never know
http://svn.apache.org/viewvc?view=revision&revision=1230927
#118730# Changed SvgClipPathNode to use MaskPrimitive2D for primitive
representation instead of TransparencePrimitive2D
http://svn.apache.org/viewvc?view=revision&revision=1231198
#118822# secured 3D geometry creation (slices) by subdividing the 2D
source polyPolygon early
http://svn.apache.org/viewvc?view=revision&revision=1234749
#118829# enhanced Svg gradient quality, obstacles avoided
http://svn.apache.org/viewvc?view=revision&revision=1235361
#118834# Unified usage of TextBreakupHelper as single tooling class
for i18n text primitive breakup
http://svn.apache.org/viewvc?view=revision&revision=1236110
#118853# added square pixel size limit to conversion of
TransparencePrimitive2D to Metafile action
http://svn.apache.org/viewvc?view=revision&revision=1237656
#118824# coreccted mirroring and boundrect when the graphicmanager
is used for bitmap output
http://svn.apache.org/viewvc?view=revision&revision=1240097
#115092# Corrected VclProcessor2D::RenderPolygonStrokePrimitive2D for
various optimization scenarios
http://svn.apache.org/viewvc?view=revision&revision=1241434
#118783# Corrected errors in ID strings, corrected Svg line/fill export,
corrected polygon close state
http://svn.apache.org/viewvc?view=revision&revision=1232006
#118796# corrected null-pointer usage in SVG text exporter
http://svn.apache.org/viewvc?view=revision&revision=1240262
#118729# Use GraphicStreamUrl and GraphicUrl to allow multi image
import with linked graphics, too
http://svn.apache.org/viewvc?view=revision&revision=1229962
#118898# corrected error in GDIMetaFile::GetBoundRect in handling
MetaFloatTransparentAction
http://svn.apache.org/viewvc?view=revision&revision=1293349
#118855# Corrected handling of possibly created empty clipRegions
after PolyPolygon clipping
http://svn.apache.org/viewvc?view=revision&revision=1237725
#115962# Better (but not yet optimal, see comments in task) handling
of MetaFloatTransparentAction in PDF export
http://svn.apache.org/viewvc?view=revision&revision=1241078
IP clearance: #118466# This patch removes librsvg, libcroco, libgsf, ...
http://svn.apache.org/viewvc?view=revision&revision=1200879
118779# Added svg content streaming in/out to ImpGraphic stream operators
http://svn.apache.org/viewvc?view=revision&revision=1231908
linecap: correctons for WaE and mac drawing
http://svn.apache.org/viewvc?view=revision&revision=1232793
svg: uses current system Dpi for Svg replacement image creation
http://svn.apache.org/viewvc?view=revision&revision=1233948
Patches contributed by Mathias Bauer (and others)
gnumake4 work variously
http://svn.apache.org/viewvc?view=revision&revision=1394326
http://svn.apache.org/viewvc?view=revision&revision=1396797
http://svn.apache.org/viewvc?view=revision&revision=1397315
http://svn.apache.org/viewvc?view=revision&revision=1394326
Remove duplicate header includes.
cws mba34issues01: #i117720#: convert assertion into warning
http://svn.apache.org/viewvc?view=revision&revision=1172352
118485 - Styles for OLEs are not saved. Submitted by Armin Le Grand.
http://svn.apache.org/viewvc?view=revision&revision=1182166
cws mba34issues01: #i117714#: remove assertion
http://svn.apache.org/viewvc?view=revision&revision=1172357
Patch contributed by Jurgen Schmidt
add some additional checks to ensure proper reading operations
http://svn.apache.org/viewvc?view=revision&revision=1209022
mostly prefer our stream / bounds checking work.
Patches contributed by Herbert Duerr
#i118816# add clarifying comment regarding Font::*Color*() methods
http://svn.apache.org/viewvc?view=revision&revision=1233833
extend macro->string handling for empty strings
http://svn.apache.org/viewvc?view=revision&revision=1175801
avoid magic constants for SALCOLOR_NONE
http://svn.apache.org/viewvc?view=revision&revision=1177543
initialize slant properly in ImplFontMetricData constructor (author=iorsh)
http://svn.apache.org/viewvc?view=revision&revision=1177551
#i118675# make check for extension updates more stable
http://svn.apache.org/viewvc?view=revision&revision=1214797
#a118617# remove VBasicEventListener.dll binary
There are no known users depending on its CLSID
http://svn.apache.org/viewvc?view=revision&revision=1203697
Patches contributed by Ariel Constenla-Haile
Fix build breaker on Linux/gcc
http://svn.apache.org/viewvc?view=revision&revision=1221104
Fix crash when trying to instantiate css.graphic.GraphicRasterizer_RSVG
http://svn.apache.org/viewvc?view=revision&revision=1215559
Patches contributed by Oliver-Rainer Wittmann
sw34bf06: #i117962# - method <SwFlyFrm::IsPaint(..)> - consider
instances of <SwFlyDrawObj>
http://svn.apache.org/viewvc?view=revision&revision=1172120
sw34bf06: #i117783# - Writer's implementation of XPagePrintable -
apply print settings to new printing routines
http://svn.apache.org/viewvc?view=revision&revision=1172115
gnumake4 work variously from Hans-Joachim Lankenau
http://svn.apache.org/viewvc?view=revision&revision=1397315
http://svn.apache.org/viewvc?view=revision&revision=1396797
http://svn.apache.org/viewvc?view=revision&revision=1396782
http://svn.apache.org/viewvc?view=revision&revision=1394707
plus some amount of re-splitting of legacy headers.
Patch contributed by Pavel Janik
WaE: Remove unused variables.
http://svn.apache.org/viewvc?view=revision&revision=1230697
Patches contributed by Takashi Ono
mingwport35: i#117795: MinGW port fix for vcl2gnumake
http://svn.apache.org/viewvc?view=revision&revision=1172091
mingwport35: i#117795: MinGW port fix for vcl2gnumake
http://svn.apache.org/viewvc?view=revision&revision=1172091
Patch contributed by Christian Lippka
impress212: #i98044# re enable Text menu for outline and title shapes
http://svn.apache.org/viewvc?view=revision&revision=1167639
Patch contributed by Andre Fischer
118674: Made category B code optional and disabled by default.
http://svn.apache.org/viewvc?view=revision&revision=1215131
118881: Ignore empty paragraphs after bullets.
http://svn.apache.org/viewvc?view=revision&revision=1296205
Patches contributed by Philipp Lohmann
ooo340fixes: #i117780# use rtl allocator
http://svn.apache.org/viewvc?view=revision&revision=1172087
ooo34gsl02: #i117807# fix an off by one error (index actually
inside the pfb section header)
http://svn.apache.org/viewvc?view=revision&revision=1167576
various cleanups, related compilation fixes, warning cleanups, re-working
of obsolete stl template pieces to use boost instead, changed string
classes, re-adapt KDE about data, about dialog, fixing warnings,
and other fixes & improvements.
Disable svg import / render for about/ branding code-paths for now.
Restore full icon theme set.
Remove OS/2 conditionals and sources.
Remove conflicting gtk/full-screen monitors support.
Retain existing svg rasterizer files - temporarily disabled.
Standardize stringificaiton and fixup dllpostfix issues.
Rename SvgGradientHelper::== to equalTo to avoid overloading issues.
Use the flat GdiPlus API for LineCaps calls.
2012-10-09 12:22:23 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the LibreOffice project.
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*
|
|
|
|
* This file incorporates work covered by the following license notice:
|
|
|
|
*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
|
|
* with this work for additional information regarding copyright
|
|
|
|
* ownership. The ASF licenses this file to you 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 .
|
|
|
|
*/
|
2007-04-11 16:56:01 +00:00
|
|
|
|
2013-10-23 19:10:20 +02:00
|
|
|
#ifndef INCLUDED_VCL_GRAPHICTOOLS_HXX
|
|
|
|
#define INCLUDED_VCL_GRAPHICTOOLS_HXX
|
2007-04-11 16:56:01 +00:00
|
|
|
|
|
|
|
#include <vcl/dllapi.h>
|
|
|
|
#include <sal/types.h>
|
|
|
|
#include <rtl/string.hxx>
|
|
|
|
#include <tools/color.hxx>
|
|
|
|
#include <tools/poly.hxx>
|
|
|
|
#include <vcl/graph.hxx>
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <vector>
|
|
|
|
|
2015-10-11 18:21:11 +02:00
|
|
|
class SvStream;
|
|
|
|
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Encapsulates geometry and associated attributes of a graphical 'pen stroke'
|
|
|
|
|
|
|
|
@attention Widespread use is deprecated. See declarations above
|
|
|
|
for the way to go. Especially the copied enums from svx/xenum.hxx
|
|
|
|
are troublesome.
|
|
|
|
|
|
|
|
Use this class to store geometry and attributes of a graphical
|
|
|
|
'pen stroke', such as pen width, dashing etc. The geometry is the
|
|
|
|
so-called 'path' along which the stroke is traced, with the given
|
|
|
|
pen width. The cap type determines how the open ends of the path
|
|
|
|
should be drawn. If the geometry consists of more than one
|
|
|
|
segment, the join type determines in which way the segments are
|
|
|
|
joined.
|
|
|
|
*/
|
|
|
|
class VCL_DLLPUBLIC SvtGraphicStroke
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// Style for open stroke ends
|
|
|
|
enum CapType
|
|
|
|
{
|
|
|
|
/// No additional cap
|
|
|
|
capButt=0,
|
|
|
|
/// Half-round cap at the line end, the center lying at the end point
|
|
|
|
capRound,
|
|
|
|
/// Half-square cap at the line end, the center lying at the end point
|
|
|
|
capSquare
|
|
|
|
};
|
|
|
|
/// Style for joins of individual stroke segments
|
|
|
|
enum JoinType
|
|
|
|
{
|
|
|
|
/// Extend segment edges, until they cross
|
|
|
|
joinMiter=0,
|
|
|
|
/// Connect segments by a filled round arc
|
|
|
|
joinRound,
|
|
|
|
/// Connect segments by a direct straight line
|
|
|
|
joinBevel,
|
|
|
|
/// Perform no join, leads to visible gaps between thick line segments
|
|
|
|
joinNone
|
|
|
|
};
|
|
|
|
typedef ::std::vector< double > DashArray;
|
|
|
|
|
|
|
|
SvtGraphicStroke();
|
|
|
|
/** All in one constructor
|
|
|
|
|
|
|
|
See accessor method descriptions for argument description
|
|
|
|
*/
|
2015-08-16 16:45:12 -05:00
|
|
|
SvtGraphicStroke( const tools::Polygon& rPath,
|
|
|
|
const tools::PolyPolygon& rStartArrow,
|
|
|
|
const tools::PolyPolygon& rEndArrow,
|
2007-04-11 16:56:01 +00:00
|
|
|
double fTransparency,
|
|
|
|
double fStrokeWidth,
|
|
|
|
CapType aCap,
|
|
|
|
JoinType aJoin,
|
|
|
|
double fMiterLimit,
|
|
|
|
const DashArray& rDashArray ); // TODO: Dash array offset (position where to start, see PS)
|
|
|
|
|
|
|
|
// accessors
|
|
|
|
/// Query path to stroke
|
2015-08-16 16:45:12 -05:00
|
|
|
void getPath ( tools::Polygon& ) const;
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get the polygon that is put at the start of the line
|
|
|
|
|
|
|
|
The polygon is in a special normalized position: the center of
|
|
|
|
the stroked path will meet the given polygon at (0,0) from
|
|
|
|
negative y values. Thus, an arrow would have its baseline on
|
|
|
|
the x axis, going upwards to positive y values. Furthermore,
|
|
|
|
the polygon is also scaled in a special way: the width of the
|
|
|
|
joining stroke is defined to be
|
|
|
|
SvtGraphicStroke::normalizedArrowWidth (0x10000), i.e. ranging
|
|
|
|
from x=-0x8000 to x=0x8000. So, if the arrow does have this
|
|
|
|
width, it has to fit every stroke with every stroke width
|
|
|
|
exactly.
|
|
|
|
*/
|
2014-09-28 07:51:19 +02:00
|
|
|
void getStartArrow ( tools::PolyPolygon& ) const;
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get the polygon that is put at the end of the line
|
|
|
|
|
|
|
|
The polygon is in a special normalized position, and already
|
|
|
|
scaled to the desired size: the center of the stroked path
|
|
|
|
will meet the given polygon at (0,0) from negative y
|
|
|
|
values. Thus, an arrow would have its baseline on the x axis,
|
|
|
|
going upwards to positive y values. Furthermore, the polygon
|
|
|
|
is also scaled in a special way: the width of the joining
|
|
|
|
stroke is defined to be SvtGraphicStroke::normalizedArrowWidth
|
|
|
|
(0x10000), i.e. ranging from x=-0x8000 to x=0x8000. So, if the
|
|
|
|
arrow does have this width, it has to fit every stroke with
|
|
|
|
every stroke width exactly.
|
|
|
|
*/
|
2014-09-28 07:51:19 +02:00
|
|
|
void getEndArrow ( tools::PolyPolygon& ) const;
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get stroke transparency
|
|
|
|
|
|
|
|
@return the transparency, ranging from 0.0 (opaque) to 1.0 (fully translucent)
|
|
|
|
*/
|
2014-06-09 10:09:42 +02:00
|
|
|
double getTransparency () const { return mfTransparency;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get width of the stroke
|
2014-06-09 10:09:42 +02:00
|
|
|
double getStrokeWidth () const { return mfStrokeWidth;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get the style in which open stroke ends are drawn
|
2014-06-09 10:09:42 +02:00
|
|
|
CapType getCapType () const { return maCapType;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get the style in which the stroke segments are joined
|
2014-06-09 10:09:42 +02:00
|
|
|
JoinType getJoinType () const { return maJoinType;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get the maximum length of mitered joins
|
2014-06-09 10:09:42 +02:00
|
|
|
double getMiterLimit () const { return mfMiterLimit;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get an array of "on" and "off" lengths for stroke dashing
|
|
|
|
void getDashArray ( DashArray& ) const;
|
|
|
|
|
|
|
|
// mutators
|
|
|
|
/// Set path to stroke
|
2015-08-16 16:45:12 -05:00
|
|
|
void setPath ( const tools::Polygon& );
|
2013-06-17 11:12:16 +01:00
|
|
|
/** Set the polygon that is put at the start of the line
|
|
|
|
|
|
|
|
The polygon has to be in a special normalized position, and
|
|
|
|
already scaled to the desired size: the center of the stroked
|
|
|
|
path will meet the given polygon at (0,0) from negative y
|
|
|
|
values. Thus, an arrow would have its baseline on the x axis,
|
|
|
|
going upwards to positive y values. Furthermore, the polygon
|
|
|
|
also has to be scaled appropriately: the width of the joining
|
|
|
|
stroke is defined to be SvtGraphicStroke::normalizedArrowWidth
|
|
|
|
(0x10000), i.e. ranging from x=-0x8000 to x=0x8000. If your
|
|
|
|
arrow does have this width, it will fit every stroke with
|
|
|
|
every stroke width exactly.
|
|
|
|
*/
|
2014-09-28 07:51:19 +02:00
|
|
|
void setStartArrow ( const tools::PolyPolygon& );
|
2013-06-17 11:12:16 +01:00
|
|
|
/** Set the polygon that is put at the end of the line
|
|
|
|
|
|
|
|
The polygon has to be in a special normalized position, and
|
|
|
|
already scaled to the desired size: the center of the stroked
|
|
|
|
path will meet the given polygon at (0,0) from negative y
|
|
|
|
values. Thus, an arrow would have its baseline on the x axis,
|
|
|
|
going upwards to positive y values. Furthermore, the polygon
|
|
|
|
also has to be scaled appropriately: the width of the joining
|
|
|
|
stroke is defined to be SvtGraphicStroke::normalizedArrowWidth
|
|
|
|
(0x10000), i.e. ranging from x=-0x8000 to x=0x8000. If your
|
|
|
|
arrow does have this width, it will fit every stroke with
|
|
|
|
every stroke width exactly.
|
|
|
|
*/
|
2014-09-28 07:51:19 +02:00
|
|
|
void setEndArrow ( const tools::PolyPolygon& );
|
2013-03-25 21:34:51 +00:00
|
|
|
/// Affine scaling in both X and Y dimensions
|
|
|
|
void scale ( double fScaleX, double fScaleY );
|
2007-04-11 16:56:01 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// friends
|
2014-01-14 13:52:54 +02:00
|
|
|
VCL_DLLPUBLIC friend SvStream& WriteSvtGraphicStroke( SvStream& rOStm, const SvtGraphicStroke& rClass );
|
2014-01-30 13:46:42 +02:00
|
|
|
VCL_DLLPUBLIC friend SvStream& ReadSvtGraphicStroke( SvStream& rIStm, SvtGraphicStroke& rClass );
|
2007-04-11 16:56:01 +00:00
|
|
|
|
2015-08-16 16:45:12 -05:00
|
|
|
tools::Polygon maPath;
|
|
|
|
tools::PolyPolygon maStartArrow;
|
|
|
|
tools::PolyPolygon maEndArrow;
|
2007-04-11 16:56:01 +00:00
|
|
|
double mfTransparency;
|
|
|
|
double mfStrokeWidth;
|
|
|
|
CapType maCapType;
|
|
|
|
JoinType maJoinType;
|
|
|
|
double mfMiterLimit;
|
|
|
|
DashArray maDashArray;
|
|
|
|
};
|
|
|
|
|
|
|
|
/** Encapsulates geometry and associated attributes of a filled area
|
|
|
|
|
|
|
|
@attention Widespread use is deprecated. See declarations above
|
|
|
|
for the way to go. Especially the copied enums from svx/xenum.hxx
|
|
|
|
is troublesome.
|
|
|
|
|
|
|
|
Use this class to store geometry and attributes of a filled area,
|
|
|
|
such as fill color, transparency, texture or hatch. The geometry
|
|
|
|
is the so-called 'path', whose inner area will get filled
|
|
|
|
according to the attributes set. If the path is intersecting, or
|
|
|
|
one part of the path is lying fully within another part, then the
|
|
|
|
fill rule determines which parts are filled and which are not.
|
|
|
|
*/
|
|
|
|
class VCL_DLLPUBLIC SvtGraphicFill
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// Type of fill algorithm used
|
|
|
|
enum FillRule
|
|
|
|
{
|
|
|
|
/** Non-zero winding rule
|
|
|
|
|
|
|
|
Fill shape scanline-wise. Starting at the left, determine
|
|
|
|
the winding number as follows: every segment crossed that
|
|
|
|
runs counter-clockwise adds one to the winding number,
|
|
|
|
every segment crossed that runs clockwise subtracts
|
|
|
|
one. The part of the scanline where the winding number is
|
|
|
|
non-zero gets filled.
|
|
|
|
*/
|
|
|
|
fillNonZero=0,
|
|
|
|
/** Even-odd fill rule
|
|
|
|
|
|
|
|
Fill shape scanline-wise. Starting at the left, count the
|
|
|
|
number of segments crossed. If this number is odd, the
|
|
|
|
part of the scanline is filled, otherwise not.
|
|
|
|
*/
|
|
|
|
fillEvenOdd
|
|
|
|
};
|
|
|
|
/// Type of filling used
|
|
|
|
enum FillType
|
|
|
|
{
|
|
|
|
/// Fill with a specified solid color
|
|
|
|
fillSolid=0,
|
|
|
|
/// Fill with the specified gradient
|
|
|
|
fillGradient,
|
|
|
|
/// Fill with the specified hatch
|
|
|
|
fillHatch,
|
|
|
|
/// Fill with the specified texture (a Graphic object)
|
|
|
|
fillTexture
|
|
|
|
};
|
|
|
|
/// Type of hatching used
|
|
|
|
enum HatchType
|
|
|
|
{
|
|
|
|
/// horizontal parallel lines, one unit apart
|
|
|
|
hatchSingle=0,
|
2017-03-24 11:44:02 +01:00
|
|
|
/// horizontal and vertical orthogonally crossing lines, one unit apart
|
2007-04-11 16:56:01 +00:00
|
|
|
hatchDouble,
|
|
|
|
/// three crossing lines, like HatchType::hatchDouble, but
|
|
|
|
/// with an additional diagonal line, rising to the upper
|
|
|
|
/// right corner. The first diagonal line goes through the
|
|
|
|
/// upper left corner, the other are each spaced a unit apart.
|
|
|
|
hatchTriple
|
|
|
|
};
|
|
|
|
/// Type of gradient used
|
2017-03-30 12:11:39 +02:00
|
|
|
enum class GradientType {Linear, Radial, Rectangular};
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Special values for gradient step count
|
|
|
|
enum { gradientStepsInfinite=0 };
|
|
|
|
/** Homogeneous 2D transformation matrix
|
|
|
|
|
|
|
|
This is a 2x3 matrix representing an affine transformation on
|
|
|
|
the R^2, in the usual C/C++ row major form. It is structured as follows:
|
|
|
|
<pre>
|
|
|
|
a b t_x
|
|
|
|
c d t_y
|
|
|
|
0 0 1
|
|
|
|
</pre>
|
|
|
|
where the lowest line is not stored in the matrix, since it is
|
|
|
|
constant. Variables t_x and t_y contain translational
|
|
|
|
components, a to d rotation, scale and shear (for details,
|
|
|
|
look up your favorite linear algebra/computer graphics book).
|
|
|
|
*/
|
|
|
|
struct VCL_DLLPUBLIC Transform
|
|
|
|
{
|
|
|
|
enum { MatrixSize=6 };
|
|
|
|
Transform();
|
|
|
|
double matrix[MatrixSize];
|
|
|
|
};
|
|
|
|
|
|
|
|
SvtGraphicFill();
|
|
|
|
/** All in one constructor
|
|
|
|
|
|
|
|
See accessor method descriptions for argument description
|
|
|
|
*/
|
2014-09-28 07:51:19 +02:00
|
|
|
SvtGraphicFill( const tools::PolyPolygon& rPath,
|
2007-04-11 16:56:01 +00:00
|
|
|
Color aFillColor,
|
|
|
|
double fTransparency,
|
|
|
|
FillRule aFillRule,
|
|
|
|
FillType aFillType, // TODO: Multitexturing
|
|
|
|
const Transform& aFillTransform,
|
|
|
|
bool bTiling,
|
|
|
|
HatchType aHatchType, // TODO: vector of directions and start points
|
|
|
|
Color aHatchColor,
|
|
|
|
GradientType aGradientType, // TODO: Transparent gradients (orthogonal to normal ones)
|
|
|
|
Color aGradient1stColor, // TODO: vector of colors and offsets
|
|
|
|
Color aGradient2ndColor,
|
2012-01-19 09:58:23 +00:00
|
|
|
sal_Int32 aGradientStepCount, // numbers of steps to render the gradient. gradientStepsInfinite means infinitely many.
|
2007-04-11 16:56:01 +00:00
|
|
|
const Graphic& aFillGraphic );
|
|
|
|
|
|
|
|
// accessors
|
|
|
|
/// Query path to fill
|
2014-09-28 07:51:19 +02:00
|
|
|
void getPath ( tools::PolyPolygon& ) const;
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get color used for solid fills
|
2014-06-12 14:06:28 +02:00
|
|
|
const Color& getFillColor () const { return maFillColor;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get stroke transparency
|
|
|
|
|
|
|
|
@return the transparency, ranging from 0.0 (opaque) to 1.0 (fully translucent)
|
|
|
|
*/
|
2014-06-09 10:09:42 +02:00
|
|
|
double getTransparency () const { return mfTransparency;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get fill rule used
|
2014-06-09 10:09:42 +02:00
|
|
|
FillRule getFillRule () const { return maFillRule;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get fill type used
|
|
|
|
|
|
|
|
Currently, only one of the fill types can be used
|
|
|
|
simultaneously. If you specify e.g. FillRule::fillGradient,
|
|
|
|
hatching, texture and solid fill color are ignored.
|
|
|
|
*/
|
2014-06-09 10:09:42 +02:00
|
|
|
FillType getFillType () const { return maFillType;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get transformation applied to hatch, gradient or texture during fill
|
|
|
|
|
|
|
|
A fill operation generally starts at the top left position of
|
|
|
|
the object's bounding box. At that position (if tiling is on,
|
|
|
|
also all successive positions), the specified fill graphic is
|
|
|
|
rendered, after applying the fill transformation to it. For
|
|
|
|
example, if the fill transformation contains a translation,
|
|
|
|
the fill graphic is rendered at the object's bounding box's
|
|
|
|
top left corner plus the translation components.
|
|
|
|
|
|
|
|
*/
|
|
|
|
void getTransform ( Transform& ) const;
|
|
|
|
/// deprecated
|
2014-06-09 10:09:42 +02:00
|
|
|
bool IsTiling () const { return mbTiling;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Query state of texture tiling
|
|
|
|
|
|
|
|
@return true, if texture is tiled, false, if output only once.
|
|
|
|
*/
|
2014-06-09 10:09:42 +02:00
|
|
|
bool isTiling () const { return mbTiling;}
|
2007-04-11 16:56:01 +00:00
|
|
|
/// Get type of gradient used
|
2014-06-09 10:09:42 +02:00
|
|
|
GradientType getGradientType () const { return maGradientType;}
|
2012-01-06 14:26:01 -05:00
|
|
|
|
2007-04-11 16:56:01 +00:00
|
|
|
/** Get the texture graphic used
|
|
|
|
|
|
|
|
The Graphic object returned is used to fill the geometry, if
|
|
|
|
the FillType is fillTexture. The Graphic object is always
|
|
|
|
assumed to be of size 1x1, the transformation is used to scale
|
|
|
|
it to the appropriate size.
|
|
|
|
*/
|
|
|
|
void getGraphic ( Graphic& ) const;
|
|
|
|
|
|
|
|
// mutators
|
|
|
|
/// Set path to fill
|
2014-09-28 07:51:19 +02:00
|
|
|
void setPath ( const tools::PolyPolygon& rPath );
|
2007-04-11 16:56:01 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// friends
|
2014-01-14 13:52:54 +02:00
|
|
|
VCL_DLLPUBLIC friend SvStream& WriteSvtGraphicFill( SvStream& rOStm, const SvtGraphicFill& rClass );
|
2014-01-30 13:46:42 +02:00
|
|
|
VCL_DLLPUBLIC friend SvStream& ReadSvtGraphicFill( SvStream& rIStm, SvtGraphicFill& rClass );
|
2007-04-11 16:56:01 +00:00
|
|
|
|
2014-09-28 07:51:19 +02:00
|
|
|
tools::PolyPolygon maPath;
|
2007-04-11 16:56:01 +00:00
|
|
|
Color maFillColor;
|
|
|
|
double mfTransparency;
|
|
|
|
FillRule maFillRule;
|
|
|
|
FillType maFillType;
|
|
|
|
Transform maFillTransform;
|
|
|
|
bool mbTiling;
|
|
|
|
HatchType maHatchType;
|
|
|
|
Color maHatchColor;
|
|
|
|
GradientType maGradientType;
|
|
|
|
Color maGradient1stColor;
|
|
|
|
Color maGradient2ndColor;
|
2012-01-19 09:58:23 +00:00
|
|
|
sal_Int32 maGradientStepCount;
|
2007-04-11 16:56:01 +00:00
|
|
|
Graphic maFillGraphic;
|
|
|
|
};
|
|
|
|
|
2013-10-23 19:10:20 +02:00
|
|
|
#endif // INCLUDED_VCL_GRAPHICTOOLS_HXX
|
2010-10-14 08:27:31 +02:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|