1*b1cdbd2cSJim Jagielski /************************************************************** 2*b1cdbd2cSJim Jagielski * 3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski * distributed with this work for additional information 6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski * 11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski * 13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski * under the License. 19*b1cdbd2cSJim Jagielski * 20*b1cdbd2cSJim Jagielski *************************************************************/ 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski 23*b1cdbd2cSJim Jagielski 24*b1cdbd2cSJim Jagielski // autogenerated file with codegen.pl 25*b1cdbd2cSJim Jagielski 26*b1cdbd2cSJim Jagielski #include "preextstl.h" 27*b1cdbd2cSJim Jagielski #include "cppunit/TestAssert.h" 28*b1cdbd2cSJim Jagielski #include "cppunit/TestFixture.h" 29*b1cdbd2cSJim Jagielski #include "cppunit/extensions/HelperMacros.h" 30*b1cdbd2cSJim Jagielski #include "postextstl.h" 31*b1cdbd2cSJim Jagielski 32*b1cdbd2cSJim Jagielski #include <basegfx/vector/b2isize.hxx> 33*b1cdbd2cSJim Jagielski #include <basegfx/range/b2drange.hxx> 34*b1cdbd2cSJim Jagielski #include <basegfx/point/b2ipoint.hxx> 35*b1cdbd2cSJim Jagielski #include <basegfx/polygon/b2dpolygon.hxx> 36*b1cdbd2cSJim Jagielski #include <basegfx/polygon/b2dpolygontools.hxx> 37*b1cdbd2cSJim Jagielski #include <basegfx/polygon/b2dpolypolygon.hxx> 38*b1cdbd2cSJim Jagielski #include <basegfx/polygon/b2dpolypolygontools.hxx> 39*b1cdbd2cSJim Jagielski 40*b1cdbd2cSJim Jagielski #include <basebmp/color.hxx> 41*b1cdbd2cSJim Jagielski #include <basebmp/scanlineformats.hxx> 42*b1cdbd2cSJim Jagielski #include <basebmp/bitmapdevice.hxx> 43*b1cdbd2cSJim Jagielski #include <basebmp/debug.hxx> 44*b1cdbd2cSJim Jagielski #include "tools.hxx" 45*b1cdbd2cSJim Jagielski 46*b1cdbd2cSJim Jagielski #include <iostream> 47*b1cdbd2cSJim Jagielski #include <fstream> 48*b1cdbd2cSJim Jagielski 49*b1cdbd2cSJim Jagielski using namespace ::basebmp; 50*b1cdbd2cSJim Jagielski 51*b1cdbd2cSJim Jagielski namespace 52*b1cdbd2cSJim Jagielski { 53*b1cdbd2cSJim Jagielski /* 54*b1cdbd2cSJim Jagielski std::ofstream output("32bpp_test.dump"); 55*b1cdbd2cSJim Jagielski debugDump( mpDevice32bpp, output ); 56*b1cdbd2cSJim Jagielski */ 57*b1cdbd2cSJim Jagielski 58*b1cdbd2cSJim Jagielski class FillTest : public CppUnit::TestFixture 59*b1cdbd2cSJim Jagielski { 60*b1cdbd2cSJim Jagielski private: 61*b1cdbd2cSJim Jagielski BitmapDeviceSharedPtr mpDevice1bpp; 62*b1cdbd2cSJim Jagielski BitmapDeviceSharedPtr mpDevice32bpp; 63*b1cdbd2cSJim Jagielski implTestRectFill(const BitmapDeviceSharedPtr & rDevice)64*b1cdbd2cSJim Jagielski void implTestRectFill(const BitmapDeviceSharedPtr& rDevice) 65*b1cdbd2cSJim Jagielski { 66*b1cdbd2cSJim Jagielski rDevice->clear(Color(0)); 67*b1cdbd2cSJim Jagielski 68*b1cdbd2cSJim Jagielski const basegfx::B2DRange aRect(1,1,10,10); 69*b1cdbd2cSJim Jagielski 70*b1cdbd2cSJim Jagielski const Color aCol(0xFFFFFFFF); 71*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 72*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 73*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aRect )), 74*b1cdbd2cSJim Jagielski aCol, 75*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 76*b1cdbd2cSJim Jagielski 77*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt1(1,1); 78*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("first pixel set", 79*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt1) == aCol); 80*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt2(9,9); 81*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("last pixel set", 82*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt2) == aCol); 83*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt3(0,0); 84*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("topmost pixel not set", 85*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt3) != aCol); 86*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt4(10,10); 87*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("bottommost pixel not set", 88*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt4) != aCol); 89*b1cdbd2cSJim Jagielski 90*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 81", 91*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 81); 92*b1cdbd2cSJim Jagielski } 93*b1cdbd2cSJim Jagielski implTestCornerCases(const BitmapDeviceSharedPtr & rDevice)94*b1cdbd2cSJim Jagielski void implTestCornerCases(const BitmapDeviceSharedPtr& rDevice) 95*b1cdbd2cSJim Jagielski { 96*b1cdbd2cSJim Jagielski rDevice->clear(Color(0)); 97*b1cdbd2cSJim Jagielski 98*b1cdbd2cSJim Jagielski const basegfx::B2DRange aEmpty1(0,0,0,11); 99*b1cdbd2cSJim Jagielski const basegfx::B2DRange aEmpty2(0,0,11,0); 100*b1cdbd2cSJim Jagielski const basegfx::B2DRange aVertLineLeft(0,0,1,11); 101*b1cdbd2cSJim Jagielski const basegfx::B2DRange aVertLineRight(10,0,11,11); 102*b1cdbd2cSJim Jagielski const basegfx::B2DRange aHorzLineTop(0,0,11,1); 103*b1cdbd2cSJim Jagielski const basegfx::B2DRange aHorzLineBottom(0,10,11,11); 104*b1cdbd2cSJim Jagielski 105*b1cdbd2cSJim Jagielski const Color aCol(0xFFFFFFFF); 106*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 107*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 108*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aEmpty1 )), 109*b1cdbd2cSJim Jagielski aCol, 110*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 111*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 0", 112*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 0); 113*b1cdbd2cSJim Jagielski 114*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 115*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 116*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aEmpty2 )), 117*b1cdbd2cSJim Jagielski aCol, 118*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 119*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 0", 120*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 0); 121*b1cdbd2cSJim Jagielski 122*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 123*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 124*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aVertLineLeft )), 125*b1cdbd2cSJim Jagielski aCol, 126*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 127*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 11", 128*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 11); 129*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt1(0,0); 130*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("first pixel set", 131*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt1) == aCol); 132*b1cdbd2cSJim Jagielski 133*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 134*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 135*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aVertLineRight )), 136*b1cdbd2cSJim Jagielski aCol, 137*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 138*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 22", 139*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 22); 140*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt2(10,10); 141*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("last pixel set", 142*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt2) == aCol); 143*b1cdbd2cSJim Jagielski 144*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 145*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 146*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aHorzLineTop )), 147*b1cdbd2cSJim Jagielski aCol, 148*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 149*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 31", 150*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 31); 151*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt3(5,0); 152*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("top-middle pixel set", 153*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt3) == aCol); 154*b1cdbd2cSJim Jagielski 155*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 156*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon( 157*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect( aHorzLineBottom )), 158*b1cdbd2cSJim Jagielski aCol, 159*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 160*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 40", 161*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 40); 162*b1cdbd2cSJim Jagielski const basegfx::B2IPoint aPt4(5,10); 163*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("bottom-middle pixel set", 164*b1cdbd2cSJim Jagielski rDevice->getPixel(aPt4) == aCol); 165*b1cdbd2cSJim Jagielski 166*b1cdbd2cSJim Jagielski ::rtl::OUString aSvg = ::rtl::OUString::createFromAscii( 167*b1cdbd2cSJim Jagielski "m 0 0l7 7h-1z" ); 168*b1cdbd2cSJim Jagielski 169*b1cdbd2cSJim Jagielski basegfx::B2DPolyPolygon aPoly; 170*b1cdbd2cSJim Jagielski basegfx::tools::importFromSvgD( aPoly, aSvg ); 171*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( 172*b1cdbd2cSJim Jagielski aPoly, 173*b1cdbd2cSJim Jagielski aCol, 174*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 175*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 43", 176*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 43); 177*b1cdbd2cSJim Jagielski } 178*b1cdbd2cSJim Jagielski implTestClipping(const BitmapDeviceSharedPtr & rDevice)179*b1cdbd2cSJim Jagielski void implTestClipping(const BitmapDeviceSharedPtr& rDevice) 180*b1cdbd2cSJim Jagielski { 181*b1cdbd2cSJim Jagielski rDevice->clear(Color(0)); 182*b1cdbd2cSJim Jagielski 183*b1cdbd2cSJim Jagielski const basegfx::B2DRange aLeftTop(-10,-10,1,1); 184*b1cdbd2cSJim Jagielski const basegfx::B2DRange aRightTop(10,-10,20,1); 185*b1cdbd2cSJim Jagielski const basegfx::B2DRange aLeftBottom(-10,10,1,20); 186*b1cdbd2cSJim Jagielski const basegfx::B2DRange aRightBottom(10,10,20,20); 187*b1cdbd2cSJim Jagielski const basegfx::B2DRange aAllOver(-10,-10,20,20); 188*b1cdbd2cSJim Jagielski 189*b1cdbd2cSJim Jagielski const Color aCol(0xFFFFFFFF); 190*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( 191*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect(aLeftTop)), 192*b1cdbd2cSJim Jagielski aCol, 193*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 194*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 1", 195*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 1); 196*b1cdbd2cSJim Jagielski 197*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( 198*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect(aRightTop)), 199*b1cdbd2cSJim Jagielski aCol, 200*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 201*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 2", 202*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 2); 203*b1cdbd2cSJim Jagielski 204*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( 205*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect(aLeftBottom)), 206*b1cdbd2cSJim Jagielski aCol, 207*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 208*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 3", 209*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 3); 210*b1cdbd2cSJim Jagielski 211*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( 212*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect(aRightBottom)), 213*b1cdbd2cSJim Jagielski aCol, 214*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 215*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 4", 216*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 4); 217*b1cdbd2cSJim Jagielski 218*b1cdbd2cSJim Jagielski rDevice->fillPolyPolygon( basegfx::B2DPolyPolygon( 219*b1cdbd2cSJim Jagielski basegfx::tools::createPolygonFromRect(aAllOver)), 220*b1cdbd2cSJim Jagielski aCol, 221*b1cdbd2cSJim Jagielski DrawMode_PAINT ); 222*b1cdbd2cSJim Jagielski CPPUNIT_ASSERT_MESSAGE("number of rendered pixel is not 121", 223*b1cdbd2cSJim Jagielski countPixel( rDevice, aCol ) == 121); 224*b1cdbd2cSJim Jagielski } 225*b1cdbd2cSJim Jagielski 226*b1cdbd2cSJim Jagielski public: setUp()227*b1cdbd2cSJim Jagielski void setUp() 228*b1cdbd2cSJim Jagielski { 229*b1cdbd2cSJim Jagielski const basegfx::B2ISize aSize(11,11); 230*b1cdbd2cSJim Jagielski mpDevice1bpp = createBitmapDevice( aSize, 231*b1cdbd2cSJim Jagielski true, 232*b1cdbd2cSJim Jagielski Format::ONE_BIT_MSB_PAL ); 233*b1cdbd2cSJim Jagielski mpDevice32bpp = createBitmapDevice( aSize, 234*b1cdbd2cSJim Jagielski true, 235*b1cdbd2cSJim Jagielski Format::THIRTYTWO_BIT_TC_MASK ); 236*b1cdbd2cSJim Jagielski } 237*b1cdbd2cSJim Jagielski testRectFill()238*b1cdbd2cSJim Jagielski void testRectFill() 239*b1cdbd2cSJim Jagielski { 240*b1cdbd2cSJim Jagielski implTestRectFill( mpDevice1bpp ); 241*b1cdbd2cSJim Jagielski implTestRectFill( mpDevice32bpp ); 242*b1cdbd2cSJim Jagielski } 243*b1cdbd2cSJim Jagielski testClipping()244*b1cdbd2cSJim Jagielski void testClipping() 245*b1cdbd2cSJim Jagielski { 246*b1cdbd2cSJim Jagielski implTestClipping( mpDevice1bpp ); 247*b1cdbd2cSJim Jagielski implTestClipping( mpDevice32bpp ); 248*b1cdbd2cSJim Jagielski } 249*b1cdbd2cSJim Jagielski testCornerCases()250*b1cdbd2cSJim Jagielski void testCornerCases() 251*b1cdbd2cSJim Jagielski { 252*b1cdbd2cSJim Jagielski implTestCornerCases( mpDevice1bpp ); 253*b1cdbd2cSJim Jagielski implTestCornerCases( mpDevice32bpp ); 254*b1cdbd2cSJim Jagielski } 255*b1cdbd2cSJim Jagielski 256*b1cdbd2cSJim Jagielski // Change the following lines only, if you add, remove or rename 257*b1cdbd2cSJim Jagielski // member functions of the current class, 258*b1cdbd2cSJim Jagielski // because these macros are need by auto register mechanism. 259*b1cdbd2cSJim Jagielski 260*b1cdbd2cSJim Jagielski CPPUNIT_TEST_SUITE(FillTest); 261*b1cdbd2cSJim Jagielski CPPUNIT_TEST(testRectFill); 262*b1cdbd2cSJim Jagielski CPPUNIT_TEST(testClipping); 263*b1cdbd2cSJim Jagielski CPPUNIT_TEST(testCornerCases); 264*b1cdbd2cSJim Jagielski CPPUNIT_TEST_SUITE_END(); 265*b1cdbd2cSJim Jagielski }; 266*b1cdbd2cSJim Jagielski 267*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------------- 268*b1cdbd2cSJim Jagielski CPPUNIT_TEST_SUITE_REGISTRATION(FillTest); 269*b1cdbd2cSJim Jagielski } 270*b1cdbd2cSJim Jagielski 271*b1cdbd2cSJim Jagielski 272*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------------- 273*b1cdbd2cSJim Jagielski 274*b1cdbd2cSJim Jagielski // this macro creates an empty function, which will called by the RegisterAllFunctions() 275*b1cdbd2cSJim Jagielski // to let the user the possibility to also register some functions by hand. 276*b1cdbd2cSJim Jagielski //NOADDITIONAL; 277*b1cdbd2cSJim Jagielski 278