summaryrefslogtreecommitdiff
path: root/drawinglayer
diff options
context:
space:
mode:
authorIvo Hinkelmann <ihi@openoffice.org>2009-04-03 15:03:38 +0000
committerIvo Hinkelmann <ihi@openoffice.org>2009-04-03 15:03:38 +0000
commita10ddd5c8f8e588289c04dfabaaafc199c8738d9 (patch)
treedd5116d5e428fd391c349f47f41f35ffb27cfebb /drawinglayer
parent3480d21093541e4e6a05de277af669e495144ea9 (diff)
CWS-TOOLING: integrate CWS aw068_DEV300
2009-03-31 11:29:56 +0200 aw r270267 : #i100373# corrected FontScaling expression in MetaFile creation
Diffstat (limited to 'drawinglayer')
-rw-r--r--drawinglayer/source/processor2d/vclprocessor2d.cxx26
1 files changed, 25 insertions, 1 deletions
diff --git a/drawinglayer/source/processor2d/vclprocessor2d.cxx b/drawinglayer/source/processor2d/vclprocessor2d.cxx
index 2479891f58d6..bc6059c3223b 100644
--- a/drawinglayer/source/processor2d/vclprocessor2d.cxx
+++ b/drawinglayer/source/processor2d/vclprocessor2d.cxx
@@ -162,7 +162,31 @@ namespace drawinglayer
// #i96581# Get the font forced without FontStretching (use FontHeight as FontWidth)
Font aFont(primitive2d::getVclFontFromFontAttributes(
rTextCandidate.getFontAttributes(),
- aScale.getY(),
+
+ // #i100373# FontScaling
+ //
+ // There are two different definitions for unscaled fonts, (1) 0==width and
+ // (2) height==width where (2) is the more modern one supported on all non-WIN32
+ // systems and (1) is the old one coming from WIN16-VCL definitions where
+ // that ominous FontWidth (available over FontMetric) is involved. While
+ // WIN32 only supports (1), all other systems support (2). When on WIN32, the
+ // support for (1) is ensured inside getVclFontFromFontAttributes.
+ //
+ // The former usage of (2) leads to problems when it is used on non-WIN32 systems
+ // and exported to MetaFile FontActions where the scale is taken over unseen. When
+ // such a MetaFile is imported on a WIN32-System supporting (1), all fonts are
+ // seen as scaled an look wrong.
+ //
+ // The simplest and fastest solution is to fallback to (1) independent from the
+ // system we are running on.
+ //
+ // The best solution would be a system-independent Y-value just expressing the
+ // font scaling, e.g. when (2) is used and width == height, use 1.0 as Y-Value,
+ // which would also solve the involved ominous FontWidth value for WIN32-systems.
+ // This is a region which needs redesign urgently.
+ //
+ 0, // aScale.getY(),
+
aScale.getY(),
fRotate,
*mpOutputDevice));