/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * 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 . */ #include #include #include #include "ConversionHelper.hxx" #include "WrapPolygonHandler.hxx" #include "dmapperLoggers.hxx" namespace writerfilter { using resourcemodel::resolveSprmProps; namespace dmapper { WrapPolygon::WrapPolygon() { } WrapPolygon::~WrapPolygon() { } void WrapPolygon::addPoint(const awt::Point & rPoint) { mPoints.push_back(rPoint); } WrapPolygon::Points_t::const_iterator WrapPolygon::begin() const { return mPoints.begin(); } WrapPolygon::Points_t::const_iterator WrapPolygon::end() const { return mPoints.end(); } WrapPolygon::Points_t::iterator WrapPolygon::begin() { return mPoints.begin(); } WrapPolygon::Points_t::iterator WrapPolygon::end() { return mPoints.end(); } size_t WrapPolygon::size() const { return mPoints.size(); } WrapPolygon::Pointer_t WrapPolygon::move(const awt::Point & rPoint) { WrapPolygon::Pointer_t pResult(new WrapPolygon); Points_t::iterator aIt = begin(); Points_t::iterator aItEnd = end(); while (aIt != aItEnd) { awt::Point aPoint(aIt->X + rPoint.X, aIt->Y + rPoint.Y); pResult->addPoint(aPoint); ++aIt; } return pResult; } WrapPolygon::Pointer_t WrapPolygon::scale(const Fraction & rFractionX, const Fraction & rFractionY) { WrapPolygon::Pointer_t pResult(new WrapPolygon); Points_t::iterator aIt = begin(); Points_t::iterator aItEnd = end(); while (aIt != aItEnd) { awt::Point aPoint(Fraction(aIt->X) * rFractionX, Fraction(aIt->Y) * rFractionY); pResult->addPoint(aPoint); ++aIt; } return pResult; } WrapPolygon::Pointer_t WrapPolygon::correctWordWrapPolygon(const awt::Size & rSrcSize, const awt::Size & rDstSize) { WrapPolygon::Pointer_t pResult; const sal_uInt32 nWrap100Percent = 21600; Fraction aMove(nWrap100Percent, rSrcSize.Width); aMove = aMove * Fraction(15, 1); awt::Point aMovePoint(aMove, 0); pResult = move(aMovePoint); Fraction aScaleX(nWrap100Percent, Fraction(nWrap100Percent) + aMove); Fraction aScaleY(nWrap100Percent, Fraction(nWrap100Percent) - aMove); pResult = pResult->scale(aScaleX, aScaleY); Fraction aScaleDestX(rDstSize.Width, nWrap100Percent); Fraction aScaleDestY(rDstSize.Height, nWrap100Percent); pResult = pResult->scale(aScaleDestX, aScaleDestY); return pResult; } drawing::PointSequenceSequence WrapPolygon::getPointSequenceSequence() const { drawing::PointSequenceSequence aPolyPolygon(1L); drawing::PointSequence * pPolygon = aPolyPolygon.getArray(); pPolygon->realloc(size()); sal_uInt32 n = 0; Points_t::const_iterator aIt = begin(); Points_t::const_iterator aItEnd = end(); while (aIt != aItEnd) { (*pPolygon)[n] = *aIt; ++n; ++aIt; } return aPolyPolygon; } WrapPolygonHandler::WrapPolygonHandler() : LoggedProperties(dmapper_logger, "WrapPolygonHandler") , mpPolygon(new WrapPolygon) { } WrapPolygonHandler::~WrapPolygonHandler() { } void WrapPolygonHandler::lcl_attribute(Id Name, Value & val) { sal_Int32 nIntValue = val.getInt(); switch(Name) { case NS_ooxml::LN_CT_Point2D_x: /* WRITERFILTERSTATUS: done: 100, planned: 0.5, spent: 0 */ mnX = nIntValue; break; case NS_ooxml::LN_CT_Point2D_y: /* WRITERFILTERSTATUS: done: 100, planned: 0.5, spent: 0 */ mnY = nIntValue; break; default: #ifdef DEBUG_WRAP_POLYGON_HANDLER dmapper_logger->element("unhandled"); #endif break; } } void WrapPolygonHandler::lcl_sprm(Sprm & _sprm) { switch (_sprm.getId()) { case NS_ooxml::LN_CT_WrapPath_lineTo: case NS_ooxml::LN_CT_WrapPath_start: /* WRITERFILTERSTATUS: done: 100, planned: 0.5, spent: 0 */ { resolveSprmProps(*this, _sprm); awt::Point aPoint(mnX, mnY); mpPolygon->addPoint(aPoint); } break; default: #ifdef DEBUG_WRAP_POLYGON_HANDLER dmapper_logger->element("unhandled"); #endif break; } } WrapPolygon::Pointer_t WrapPolygonHandler::getPolygon() { return mpPolygon; } }} /* vim:set shiftwidth=4 softtabstop=4 expandtab: */