/* -*- 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 #include #include #include #include #include #include #include #include #include #include #include "tools.hxx" using namespace ::basebmp; namespace { class ClipTest : public CppUnit::TestFixture { private: BitmapDeviceSharedPtr mpClipMask; BitmapDeviceSharedPtr mpDevice1bpp; BitmapDeviceSharedPtr mpDevice32bpp; void implTestPixelClip(const BitmapDeviceSharedPtr& rDevice) { const Color aBgCol(0); rDevice->clear(aBgCol); const basegfx::B2IPoint aPt(0,0); const Color aCol(0xFFFFFFFF); rDevice->setPixel( aPt, aCol, DrawMode_PAINT, mpClipMask ); CPPUNIT_ASSERT_MESSAGE("get/setPixel clip #1", rDevice->getPixel(aPt) == aBgCol); const basegfx::B2IPoint aPt2(10,10); rDevice->setPixel( aPt2, aCol, DrawMode_PAINT, mpClipMask ); CPPUNIT_ASSERT_MESSAGE("get/setPixel clip #2", rDevice->getPixel(aPt2) == aBgCol); const basegfx::B2IPoint aPt1(10,0); rDevice->setPixel( aPt1, aCol, DrawMode_PAINT, mpClipMask ); CPPUNIT_ASSERT_MESSAGE("get/setPixel clip #3", rDevice->getPixel(aPt1) != aBgCol); const basegfx::B2IPoint aPt3(0,10); rDevice->setPixel( aPt3, aCol, DrawMode_PAINT, mpClipMask ); CPPUNIT_ASSERT_MESSAGE("get/setPixel clip #4", rDevice->getPixel(aPt3) != aBgCol); } void implTestLineClip(const BitmapDeviceSharedPtr& rDevice) { const Color aBgCol(0); rDevice->clear(aBgCol); const basegfx::B2IPoint aPt1(0,0); const basegfx::B2IPoint aPt2(1,9); const Color aCol(0xFFFFFFFF); rDevice->drawLine( aPt1, aPt2, aCol, DrawMode_PAINT, mpClipMask ); const basegfx::B2IPoint aPt3(1,5); CPPUNIT_ASSERT_MESSAGE("get line pixel", rDevice->getPixel(aPt3) != aBgCol); CPPUNIT_ASSERT_MESSAGE("number of rendered line pixel is not 4", countPixel( rDevice, rDevice->getPixel(aPt3) ) == 4); rDevice->drawLine( aPt1, aPt2, aCol, DrawMode_XOR, mpClipMask ); CPPUNIT_ASSERT_MESSAGE("number of xor-rendered line pixel is not 0", countPixel( rDevice, rDevice->getPixel(aPt3) ) == 121); } void implTestFillClip(const BitmapDeviceSharedPtr& rDevice) { rDevice->clear(Color(0)); const basegfx::B2DRange aAllOver(-10,-10,20,20); const Color aCol(0xFFFFFFFF); rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( basegfx::tools::createPolygonFromRect(aAllOver)), aCol, DrawMode_PAINT, mpClipMask ); const basegfx::B2IPoint aPt(0,10); CPPUNIT_ASSERT_MESSAGE("number of clipped pixel is not 30", countPixel( rDevice, rDevice->getPixel(aPt) ) == 121-30); rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( basegfx::tools::createPolygonFromRect(aAllOver)), aCol, DrawMode_PAINT ); CPPUNIT_ASSERT_MESSAGE("number of filled pixel is not 121", countPixel( rDevice, rDevice->getPixel(aPt) ) == 121); rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( basegfx::tools::createPolygonFromRect(aAllOver)), aCol, DrawMode_XOR, mpClipMask ); CPPUNIT_ASSERT_MESSAGE("number of xor-cleared pixel is not 91", countPixel( rDevice, rDevice->getPixel(aPt) ) == 121-30); } void implTestBmpClip(const BitmapDeviceSharedPtr& rDevice) { BitmapDeviceSharedPtr pBmp( cloneBitmapDevice( basegfx::B2IVector(3,3), rDevice )); Color aCol1(0); Color aCol2(0xFFFFFFFF); pBmp->clear(aCol1); pBmp->setPixel(basegfx::B2IPoint(0,0),aCol2,DrawMode_PAINT); pBmp->setPixel(basegfx::B2IPoint(1,1),aCol2,DrawMode_PAINT); pBmp->setPixel(basegfx::B2IPoint(2,2),aCol2,basebmp::DrawMode_PAINT); rDevice->clear(aCol1); rDevice->drawBitmap(pBmp, basegfx::B2IBox(0,0,3,3), basegfx::B2IBox(-1,-1,4,4), DrawMode_PAINT, mpClipMask); const basegfx::B2IPoint aPt(1,1); CPPUNIT_ASSERT_MESSAGE("number of clipped pixel is not 5", countPixel( rDevice, rDevice->getPixel(aPt) ) == 5); } void implTestMaskColorClip(const BitmapDeviceSharedPtr& rDevice) { BitmapDeviceSharedPtr pBmp( createBitmapDevice( rDevice->getSize(), true, FORMAT_EIGHT_BIT_GREY )); OUString aSvg( "m 0 0h5v10h5v-5h-10z" ); basegfx::B2DPolyPolygon aPoly; basegfx::tools::importFromSvgD( aPoly, aSvg, false, NULL ); const basebmp::Color aCol(0xFF); pBmp->clear( basebmp::Color(0) ); pBmp->fillPolyPolygon( aPoly, aCol, basebmp::DrawMode_PAINT ); const basegfx::B2IBox aSourceRect(0,0,10,10); const basegfx::B2IPoint aDestLeftTop(0,0); const Color aCol2(0xF0F0F0F0); rDevice->drawMaskedColor( aCol2, pBmp, aSourceRect, aDestLeftTop, mpClipMask ); const basegfx::B2IPoint aPt(1,1); CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 41", countPixel( rDevice, rDevice->getPixel(aPt) ) == 41); } public: void setUp() { const basegfx::B2ISize aSize(11,11); mpClipMask = createBitmapDevice( aSize, true, FORMAT_ONE_BIT_MSB_GREY ); mpDevice1bpp = createBitmapDevice( aSize, true, FORMAT_ONE_BIT_MSB_PAL ); mpDevice32bpp = createBitmapDevice( aSize, true, FORMAT_THIRTYTWO_BIT_TC_MASK_BGRA ); OUString aSvg( "m 0 0 h5 l5 5 v5 h-5 l-5-5 z" ); basegfx::B2DPolyPolygon aPoly; basegfx::tools::importFromSvgD( aPoly, aSvg, false, NULL ); mpClipMask->clear(Color(0)); mpClipMask->drawPolygon( aPoly.getB2DPolygon(0), Color(0xFFFFFFFF), DrawMode_PAINT ); } void testPixelClip() { implTestPixelClip( mpDevice1bpp ); implTestPixelClip( mpDevice32bpp ); } void testLineClip() { implTestLineClip( mpDevice1bpp ); implTestLineClip( mpDevice32bpp ); } void testFillClip() { implTestFillClip( mpDevice1bpp ); implTestFillClip( mpDevice32bpp ); } void testBmpClip() { implTestBmpClip( mpDevice1bpp ); implTestBmpClip( mpDevice32bpp ); } void testMaskColorClip() { implTestMaskColorClip( mpDevice1bpp ); implTestMaskColorClip( mpDevice32bpp ); } // Change the following lines only, if you add, remove or rename // member functions of the current class, // because these macros are need by auto register mechanism. CPPUNIT_TEST_SUITE(ClipTest); CPPUNIT_TEST(testPixelClip); CPPUNIT_TEST(testLineClip); CPPUNIT_TEST(testFillClip); CPPUNIT_TEST(testBmpClip); CPPUNIT_TEST(testMaskColorClip); CPPUNIT_TEST_SUITE_END(); }; CPPUNIT_TEST_SUITE_REGISTRATION(ClipTest); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ 'feature/5-1-pick'>feature/5-1-pick LibreOffice 核心代码仓库文档基金会
summaryrefslogtreecommitdiff
path: root/opencl
AgeCommit message (Expand)Author
2020-08-30Goodbye O[U]StringView, welcome O[U]String::ConcatStephan Bergmann
2020-07-10replace usage of blacklist with excludelist for IWYUThorsten Behrens
2020-07-10replace usage of whitelist with allowlistThorsten Behrens
2020-07-10replace usage of blacklist with denylistThorsten Behrens
2020-04-03loplugin:flatten in openclNoel Grandin
2020-03-12Revert "loplugin:constfields in oox"Noel Grandin
2020-02-07merge OpenGLZone and OpenCLZone into one generic codeLuboš Luňák
2020-01-28New loplugin:unsignedcompareStephan Bergmann
2019-12-11pickBestDevice return is ignoredCaolán McNamara
2019-12-11ensure cache dir is createdCaolán McNamara
2019-11-26Remove unused OpenCLEnv::mpOclCmdQueueStephan Bergmann
2019-10-19Directly use OUStringBuffer::append overload taking a single sal_UnicodeStephan Bergmann
2019-10-17Remove some memset callsMike Kaganski
2019-10-17Rename OUStringLiteral1 to OUStringCharStephan Bergmann
2019-10-14Fix misuse of OStringLiteralStephan Bergmann
2019-10-14loplugin:stringadd look for unnecessary temporariesNoel Grandin
2019-09-18-Werror=volatile in OpenCLZoneStephan Bergmann
2019-08-31Add version resource to executables where it was missingMike Kaganski
2019-08-20loplugin:constvars in i18npool..openclNoel Grandin
2019-07-31Improved loplugin:stringconstant (now that GCC 7 supports it): openclStephan Bergmann
2019-07-23Fix typosAndrea Gelmini
2019-07-18cid#1448546 Logically dead codeCaolán McNamara
2019-05-29tdf#42949 Fix IWYU warnings in opencl/Gabor Kelemen
2019-05-22New loplugin:dataStephan Bergmann
2019-04-29test in a separate helper process if OpenCL crashes (tdf#112252)Luboš Luňák
2019-02-15Simplify containers iterations in oox, opencl, packageArkadiy Illarionov
2019-01-11Replace OUStringBuffer::appendCopy with append(std::u16string_view)Stephan Bergmann
2018-11-21improve function-local statics in forms..reportdesignNoel Grandin
2018-11-14$SC_FORCE_CALCULATION to force Calc use opencl/threads for everythingLuboš Luňák
2018-11-01clang-tidy: (WIP) bugprone-too-small-loop-variable findingsTamás Zolnai
2018-10-24remove more rtl::OUString and OString prefixesNoel Grandin
2018-10-24tdf#42949 Fix IWYU warnings in include/opencl/*Gabor Kelemen
2018-10-18clang-tidy readability-simplify-boolean-exprNoel Grandin
2018-10-15loplugin:constfields in ooxNoel Grandin
2018-09-17New loplugin:externalStephan Bergmann
2018-08-14create appendCopy method in OUStringBufferNoel Grandin
2018-07-27new loplugin:stringloop, and applied in variousNoel Grandin
2018-06-22tdf#42949 Fix IWYU warnings in include/sal/Gabor Kelemen
2018-06-05tdf#42949 remove unused compheler includes ..Jochen Nitschke
2018-01-15convert a<b?a:b to std::min(a,b)Noel Grandin
2018-01-12More loplugin:cstylecast: openclStephan Bergmann
2017-12-19Explicitly qualify ICU types with icu:: namespaceEike Rathke