windowing/windowserver/tauto/DLLDRAW.H
author MattD <ext-matt.4.davies@nokia.com>
Fri, 24 Sep 2010 16:58:15 +0100
branchEGL_MERGE
changeset 191 6356de74619b
parent 0 5d03bc08d59c
permissions -rw-r--r--
merged faisal's branch of EGL_MERGE on top of all of the dead heads of Jose. This makes Faisal's changes the 'tip' of EGL_MERGE again. No changes.

// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
// Lots of different Drawing Commands
// 
//

	gc->SetBrushColor(TRgb::Gray4(2));
	gc->Clear();
	gc->SetBrushColor(TRgb::Gray4(0));
	gc->Clear(TRect(2,2,20,5));
	gc->DrawRect(TRect(size));
	gc->SetBrushOrigin(TPoint(1,2));
	gc->SetBrushStyle(CGraphicsContext::EForwardDiagonalHatchBrush);
	gc->DrawRect(TRect(30,2,60,8));
	gc->SetBrushOrigin(TPoint(0,0));
	gc->UseBrushPattern(aBitmap);
	gc->SetBrushStyle(CGraphicsContext::EPatternedBrush);
	gc->DrawRect(TRect(60,2,90,8));
	gc->SetBrushStyle(CGraphicsContext::ENullBrush);
	gc->DiscardBrushPattern();
//
	gc->SetPenColor(TRgb::Gray4(1));
	gc->DrawLine(TPoint(10,12),TPoint(22,20));
	gc->SetPenSize(TSize(4,2));
	gc->DrawLine(TPoint(22,10),TPoint(40,20));
	gc->SetPenStyle(CGraphicsContext::EDottedPen);
	gc->SetPenSize(TSize(1,1));
	gc->SetPenColor(TRgb::Gray4(0));
	gc->DrawLine(TPoint(40,11),TPoint(60,20));
	gc->SetPenStyle(CGraphicsContext::ESolidPen);
	gc->Plot(TPoint(60,10));
//
	gc->BitBlt(TPoint(size.AsPoint()-TPoint(20,20)),aBitmap);
	gc->BitBlt(TPoint(10,30),aBitmap,TRect(0,1,8,9));
	gc->BitBltMasked(TPoint(10,40),aBitmap,TRect(1,2,8,9),aMaskBitmap,ETrue);
	gc->BitBltMasked(TPoint(20,40),aBitmap,TRect(0,0,9,9),aMaskBitmap,EFalse);
 	gc->SetOrigin(TPoint(5,50));
	gc->SetDrawMode(CGraphicsContext::EDrawModeXOR);
	gc->SetPenColor(TRgb::Gray4(3));
 	gc->SetClippingRect(TRect(0,0,20,15));
	//gc->DrawArc(TRect(0,0,20,15),TPoint(10,0),TPoint(1,8));
 	gc->CancelClippingRect();
	gc->SetDrawMode(CGraphicsContext::EDrawModePEN);
	gc->SetPenColor(TRgb::Gray4(0));
	gc->MoveTo(TPoint(25,0));
	gc->DrawLineTo(TPoint(40,5));
	gc->DrawLineBy(TPoint(-20,10));
//
	CArrayFixFlat<TPoint>* polyLineArray=new(ELeave) CArrayFixFlat<TPoint>(4);
	CleanupStack::PushL(polyLineArray);
	polyLineArray->AppendL(TPoint(8,0));
	polyLineArray->AppendL(TPoint(16,10));
	polyLineArray->AppendL(TPoint(0,3));
	polyLineArray->AppendL(TPoint(16,3));
	polyLineArray->AppendL(TPoint(0,10));
	polyLineArray->AppendL(TPoint(8,0));
	gc->SetBrushStyle(CGraphicsContext::ESolidBrush);
	gc->SetOrigin(TPoint(50,50));
	gc->DrawPolyLine(polyLineArray);
	gc->SetOrigin(TPoint(75,50));
	gc->DrawPolyLine(&(polyLineArray->At(0)),polyLineArray->Count());
	polyLineArray->Delete(5);
	gc->SetOrigin(TPoint(0,65));
	gc->DrawPolygon(polyLineArray,CGraphicsContext::EWinding);
	gc->SetOrigin(TPoint(25,65));
	gc->DrawPolygon(&(polyLineArray->At(0)),polyLineArray->Count(),CGraphicsContext::EWinding);
	gc->SetOrigin(TPoint(50,65));
	gc->DrawPolygon(polyLineArray,CGraphicsContext::EAlternate);
	gc->SetOrigin(TPoint(75,65));
	gc->DrawPolygon(&(polyLineArray->At(0)),polyLineArray->Count(),CGraphicsContext::EAlternate);
	CleanupStack::PopAndDestroy();
	gc->SetBrushStyle(CGraphicsContext::ENullBrush);
	gc->SetOrigin(TPoint(0,0));
//
	gc->DrawPie(TRect(5,80,30,100),TPoint(10,65),TPoint(35,80));
	gc->DrawEllipse(TRect(35,80,60,100));
	gc->DrawRoundRect(TRect(65,80,80,100),TSize(5,3));
	gc->DrawBitmap(TRect(10,105,40,120),aBitmap);
	gc->DrawBitmap(TRect(45,105,105,125),aBitmap,TRect(5,5,25,20));
//gc->DrawBitmap(TRect(110,40,205,125),aBitmap,TRect(5,5,25,20));
	if (aExtraDrawBitMap)
		gc->DrawBitmap(TPoint(110,70),aBitmap);
//
	gc->UseFont(aFont);
	TInt height=aFont->HeightInPixels();
	TInt ascent=aFont->AscentInPixels();
	TInt ypos=5;
	TInt xpos=100;
	gc->DrawText(_L("Test1"),TPoint(xpos,ypos+ascent));
	gc->DrawText(_L("Test2"),TRect(xpos,ypos+height,xpos+50,5+height*2),ascent);
	gc->DrawText(_L("Test3"),TRect(xpos,ypos+height*2,xpos+80,5+height*3),ascent,CGraphicsContext::ERight,10);
//
	ypos+=ascent+height*3;
	gc->SetUnderlineStyle(EUnderlineOn);
	gc->DrawText(_L("ULine"),TPoint(xpos,ypos));
	gc->SetUnderlineStyle(EUnderlineOff);
//
	gc->SetStrikethroughStyle(EStrikethroughOn);
	gc->DrawText(_L("Strike"),TPoint(xpos+50,ypos));
	gc->SetStrikethroughStyle(EStrikethroughOff);
	gc->SetCharJustification(15,3);
	gc->DrawText(_L("abc"),TPoint(xpos+100,ypos));
//
	gc->SetWordJustification(10,1);
	gc->DrawText(_L("Two Words"),TPoint(xpos+5,ypos+height));
//
	xpos = 80;
	ypos = 40;
	RRegion clipRegion(2);
//
	clipRegion.AddRect(TRect(xpos, ypos+10, xpos+30, ypos+20));
	clipRegion.AddRect(TRect(xpos, ypos+30, xpos+30, ypos+40));
	gc->SetClippingRegion(clipRegion);
//
	gc->DrawTextVertical(_L("Vertical Text"), TPoint(xpos+10, ypos+10), EFalse);
	gc->DrawTextVertical(_L("Vertical Text Box"), TRect(xpos+40, ypos+10, xpos+60, ypos+100), 15, EFalse);
//
	gc->CancelClippingRegion();
	clipRegion.Close();
//
	gc->AlphaBlendBitmaps(TPoint(xpos+60, ypos+100), aBitmap, TRect(0, 0, 20,20), aMaskBitmap, TPoint(0, 0));
//
	gc->SetPenColor(TRgb::Gray4(3));
	gc->SetBrushColor(TRgb::Gray4(0));
	gc->SetBrushStyle(CGraphicsContext::ESolidBrush);
	xpos = 0;
	ypos = 120;
	TRect mapColorRect(xpos, ypos, xpos+20, ypos+20);
	gc->DrawRect(mapColorRect);
	TRgb colours[4] = { TRgb::Gray4(3), TRgb::Gray4(0), TRgb::Gray4(0), TRgb::Gray4(3) };
	gc->MapColors(mapColorRect, colours, 2, ETrue);
//
	gc->DiscardFont();