os/graphics/printingservices/printerdriversupport/src/FBSDRV.CPP
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 1997-2010 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
#include "PDRSTD.H"
sl@0
    17
#include <fbs.h>
sl@0
    18
#include <bitdev.h>
sl@0
    19
#include <banddev.h>
sl@0
    20
#include <pdrstore.h>
sl@0
    21
#include "pdrtext.h"
sl@0
    22
sl@0
    23
EXPORT_C CFbsDrvDevice::CFbsDrvDevice()
sl@0
    24
	{
sl@0
    25
	__DECLARE_NAME(_S("CFbsDrvDevice"));
sl@0
    26
	}
sl@0
    27
sl@0
    28
EXPORT_C CFbsDrvDevice::~CFbsDrvDevice()
sl@0
    29
	{
sl@0
    30
	delete iFbsTypefaceStore;
sl@0
    31
	delete iGenTypefaceFontsList;
sl@0
    32
	delete iGenTypefaceFontsType;
sl@0
    33
	}
sl@0
    34
sl@0
    35
/** Creates a font from those available in the printer device's 
sl@0
    36
typeface store that most closely matches a font specification. 
sl@0
    37
sl@0
    38
When the font is no longer needed, call ReleaseFont().
sl@0
    39
sl@0
    40
This function is replaced by GetNearestFontToDesignHeightInTwips()
sl@0
    41
sl@0
    42
@param aFont On return, points to the font which most closely matches the 
sl@0
    43
specified font.
sl@0
    44
@param aFontSpec An absolute font specification. Its iHeight member is 
sl@0
    45
interpreted as being in twips.
sl@0
    46
@return KErrNone if successful; otherwise, another one of the system-wide error 
sl@0
    47
codes.
sl@0
    48
@deprecated */
sl@0
    49
EXPORT_C TInt CFbsDrvDevice::GetNearestFontInTwips(CFont*& aFont, const TFontSpec& aFontSpec)
sl@0
    50
	{
sl@0
    51
	return GetNearestFontToDesignHeightInTwips(aFont, aFontSpec);
sl@0
    52
	}
sl@0
    53
sl@0
    54
/** Creates a font from those available in the printer device's 
sl@0
    55
typeface store that most closely matches a font specification. 
sl@0
    56
sl@0
    57
When the font is no longer needed, call ReleaseFont().
sl@0
    58
sl@0
    59
This function replaces GetNearestFontInTwips()
sl@0
    60
sl@0
    61
@param aFont On return, points to the font which most closely matches the 
sl@0
    62
specified font.
sl@0
    63
@param aFontSpec An absolute font specification. Its iHeight member is 
sl@0
    64
interpreted as being in twips.
sl@0
    65
@return KErrNone if successful; otherwise, another one of the system-wide error 
sl@0
    66
codes. */
sl@0
    67
EXPORT_C TInt CFbsDrvDevice::GetNearestFontToDesignHeightInTwips(CFont *&aFont, const TFontSpec &aFontSpec)
sl@0
    68
	{
sl@0
    69
    TRAPD(errCode, LoadTypeFaceListL());
sl@0
    70
	if(errCode != KErrNone)
sl@0
    71
		{
sl@0
    72
		return errCode;
sl@0
    73
		}
sl@0
    74
	TInt count = iGenTypefaceFontsList->Count();
sl@0
    75
	TInt count_fbs = 0;
sl@0
    76
	TTypefaceSupport support ;				// holds typeface from iGenTypefaceFontsList
sl@0
    77
	TTypeface typeface = aFontSpec.iTypeface;	// holds typeface from aFontSpec
sl@0
    78
	TBuf<KMaxTypefaceNameLength> support_name;
sl@0
    79
	TBuf<KMaxTypefaceNameLength> typeface_name;
sl@0
    80
	TBuf<KMaxTypefaceNameLength> aname;
sl@0
    81
	typeface_name.Copy(typeface.iName);
sl@0
    82
	TInt loop;
sl@0
    83
	TInt found = 0;
sl@0
    84
	TInt listindex = 0;
sl@0
    85
	TTypefaceSupport lsupport;
sl@0
    86
	// Try to match specified font name with name from typeface font list
sl@0
    87
	for (loop = 0; (loop < count) && (typeface.iName.CompareF(support.iTypeface.iName)); loop++)
sl@0
    88
		{
sl@0
    89
		TInt index = iGenTypefaceFontsList->At(loop);
sl@0
    90
		TInt type = iGenTypefaceFontsType->At(loop);
sl@0
    91
		if (type == 0)
sl@0
    92
			{
sl@0
    93
			iTypefaceStore->TypefaceSupport(support,index);
sl@0
    94
			support_name.Copy(support.iTypeface.iName);
sl@0
    95
			}
sl@0
    96
		else if(type == 1)
sl@0
    97
			{
sl@0
    98
			iFbsTypefaceStore->TypefaceSupport(support,index);
sl@0
    99
			if(support.iIsScalable)
sl@0
   100
				{
sl@0
   101
				count_fbs++;
sl@0
   102
				support_name.Copy(support.iTypeface.iName);
sl@0
   103
				}
sl@0
   104
			}
sl@0
   105
		if (!typeface.iName.CompareF(support.iTypeface.iName))
sl@0
   106
			{
sl@0
   107
			typeface_name.Copy(support.iTypeface.iName);
sl@0
   108
			found = 1;
sl@0
   109
			}
sl@0
   110
		}
sl@0
   111
sl@0
   112
	if (found)
sl@0
   113
		{
sl@0
   114
		if (loop <= iFbsTypefaceCount)
sl@0
   115
			{
sl@0
   116
			TFontSpec fontspec(aFontSpec);
sl@0
   117
			fontspec.iTypeface=support.iTypeface;
sl@0
   118
			return iFbsTypefaceStore->GetNearestFontToDesignHeightInTwips(aFont, fontspec);
sl@0
   119
			}
sl@0
   120
		else if (loop <= count)
sl@0
   121
			{
sl@0
   122
			TFontSpec fontspec(aFontSpec);
sl@0
   123
			fontspec.iTypeface=support.iTypeface;
sl@0
   124
			return iTypefaceStore->GetNearestFontToDesignHeightInTwips(aFont, fontspec);
sl@0
   125
			}
sl@0
   126
		}
sl@0
   127
	else 
sl@0
   128
		{
sl@0
   129
		if (!typeface.IsSymbol())
sl@0
   130
			{	// To match first non-symbol, serif, proportional
sl@0
   131
			TypefaceSupport(lsupport, 0);
sl@0
   132
			while ((listindex < count) && ((lsupport.iTypeface.IsSymbol() ||
sl@0
   133
				(typeface.IsProportional() != lsupport.iTypeface.IsProportional()) ||
sl@0
   134
				(typeface.IsSerif() != lsupport.iTypeface.IsSerif()))))
sl@0
   135
				{
sl@0
   136
				TypefaceSupport(lsupport, listindex);
sl@0
   137
				aname.Copy(lsupport.iTypeface.iName);
sl@0
   138
				listindex++;
sl@0
   139
				}
sl@0
   140
			if (listindex == count)
sl@0
   141
				{	// try to match first non-symbol.proportional
sl@0
   142
				listindex = 0;
sl@0
   143
				do
sl@0
   144
					{
sl@0
   145
					TypefaceSupport(lsupport, listindex);
sl@0
   146
					aname.Copy(lsupport.iTypeface.iName);
sl@0
   147
					listindex++;
sl@0
   148
					}
sl@0
   149
				while ((listindex < count) && (lsupport.iTypeface.IsSymbol() ||
sl@0
   150
					(typeface.IsProportional() != lsupport.iTypeface.IsProportional())));
sl@0
   151
				}
sl@0
   152
			if (listindex == count)
sl@0
   153
				{	// try to match first non-symbol
sl@0
   154
				listindex = 0;
sl@0
   155
				do
sl@0
   156
					{
sl@0
   157
					TypefaceSupport(lsupport, listindex);
sl@0
   158
					aname.Copy(lsupport.iTypeface.iName);
sl@0
   159
					listindex++;
sl@0
   160
					}
sl@0
   161
				while ((listindex < count) && lsupport.iTypeface.IsSymbol());
sl@0
   162
				}
sl@0
   163
			}
sl@0
   164
		else
sl@0
   165
			{	// try to match first symbol typeface
sl@0
   166
			listindex = 0;
sl@0
   167
			TypefaceSupport(lsupport, 0);
sl@0
   168
sl@0
   169
			while ((listindex < count) && !lsupport.iTypeface.IsSymbol())
sl@0
   170
				{
sl@0
   171
				TypefaceSupport(lsupport, listindex);
sl@0
   172
				aname.Copy(lsupport.iTypeface.iName);
sl@0
   173
				listindex++;
sl@0
   174
				}
sl@0
   175
			}
sl@0
   176
		if (listindex == count)
sl@0
   177
			{
sl@0
   178
			listindex = 0;
sl@0
   179
			TypefaceSupport(lsupport, listindex);
sl@0
   180
			}
sl@0
   181
		}
sl@0
   182
		
sl@0
   183
	if (listindex <= iFbsTypefaceCount)
sl@0
   184
		{
sl@0
   185
		TFontSpec fontspec(aFontSpec);
sl@0
   186
		fontspec.iTypeface = lsupport.iTypeface;
sl@0
   187
		TBuf<KMaxTypefaceNameLength> fontspec_name;
sl@0
   188
		fontspec_name.Copy(fontspec.iTypeface.iName);
sl@0
   189
		return iFbsTypefaceStore->GetNearestFontToDesignHeightInTwips(aFont, fontspec);
sl@0
   190
		}
sl@0
   191
	else
sl@0
   192
		{
sl@0
   193
		TFontSpec fontspec(aFontSpec);
sl@0
   194
		fontspec.iTypeface = lsupport.iTypeface;
sl@0
   195
		TBuf<KMaxTypefaceNameLength> fontspec_name;
sl@0
   196
		fontspec_name.Copy(fontspec.iTypeface.iName);
sl@0
   197
		return iTypefaceStore->GetNearestFontToDesignHeightInTwips(aFont, fontspec);
sl@0
   198
		}
sl@0
   199
	}
sl@0
   200
sl@0
   201
EXPORT_C void CFbsDrvDevice::ReleaseFont(CFont* aFont)
sl@0
   202
	{
sl@0
   203
	if (aFont)
sl@0
   204
		{
sl@0
   205
		if (aFont->TypeUid() != KCFbsFontUid)
sl@0
   206
			{
sl@0
   207
			iTypefaceStore->ReleaseFont(aFont);
sl@0
   208
			}
sl@0
   209
		else
sl@0
   210
			{
sl@0
   211
			iFbsTypefaceStore->ReleaseFont(aFont);
sl@0
   212
			}
sl@0
   213
		}
sl@0
   214
	}
sl@0
   215
sl@0
   216
EXPORT_C TInt CFbsDrvDevice::NumTypefaces() const
sl@0
   217
	{
sl@0
   218
	return iGenTypefaceFontsList->Count();
sl@0
   219
	}
sl@0
   220
sl@0
   221
/**
sl@0
   222
@deprecated Interface is deprecated because it is unsafe as it may leave. It is available for backward compatibility reasons only.
sl@0
   223
@see CFbsDrvDevice::LoadTypeFaceListL
sl@0
   224
*/
sl@0
   225
sl@0
   226
EXPORT_C void CFbsDrvDevice::LoadTypeFaceList()
sl@0
   227
	{
sl@0
   228
	// Trap and Ignore the ERROR code as its a non-leaving method.
sl@0
   229
	TRAP_IGNORE(LoadTypeFaceListL());
sl@0
   230
	}
sl@0
   231
sl@0
   232
/**
sl@0
   233
New Updated LoadTypeFaceList() method
sl@0
   234
@publishedAll
sl@0
   235
@released
sl@0
   236
*/
sl@0
   237
EXPORT_C void CFbsDrvDevice::LoadTypeFaceListL()
sl@0
   238
	{
sl@0
   239
	iFbsTypefaceCount = 0;
sl@0
   240
	iPdrTypefaceCount = 0;
sl@0
   241
	if (iGenTypefaceFontsList)
sl@0
   242
		iGenTypefaceFontsList->Reset();
sl@0
   243
	else
sl@0
   244
		iGenTypefaceFontsList = new (ELeave) CArrayFixFlat<TInt>(1);
sl@0
   245
sl@0
   246
	if (iGenTypefaceFontsType)
sl@0
   247
		iGenTypefaceFontsType->Reset();
sl@0
   248
	else
sl@0
   249
		iGenTypefaceFontsType = new (ELeave) CArrayFixFlat<TInt>(1);
sl@0
   250
		
sl@0
   251
	TInt loop;
sl@0
   252
	for(loop = 0; loop < iFbsTypefaceStore->NumTypefaces(); loop++)
sl@0
   253
		{
sl@0
   254
		TTypefaceSupport support;
sl@0
   255
		iFbsTypefaceStore->TypefaceSupport(support, loop);
sl@0
   256
			{
sl@0
   257
			if (support.iIsScalable)
sl@0
   258
				{
sl@0
   259
				iGenTypefaceFontsList->AppendL(loop);
sl@0
   260
				iGenTypefaceFontsType->AppendL(1);
sl@0
   261
				iFbsTypefaceCount++;
sl@0
   262
				}
sl@0
   263
			}
sl@0
   264
		}
sl@0
   265
sl@0
   266
	for (loop = 0; loop < iTypefaceStore->NumTypefaces(); loop++)
sl@0
   267
		{
sl@0
   268
		TTypefaceSupport support;
sl@0
   269
		iTypefaceStore->TypefaceSupport(support, loop);
sl@0
   270
sl@0
   271
		TBuf<KMaxTypefaceNameLength> name;
sl@0
   272
		name.Copy(support.iTypeface.iName);
sl@0
   273
sl@0
   274
		iGenTypefaceFontsList->AppendL(loop);
sl@0
   275
		iGenTypefaceFontsType->AppendL(0);
sl@0
   276
		iPdrTypefaceCount++;
sl@0
   277
		}
sl@0
   278
	}
sl@0
   279
sl@0
   280
EXPORT_C void CFbsDrvDevice::TypefaceSupport(TTypefaceSupport& aTypefaceSupport, TInt aTypefaceIndex) const
sl@0
   281
	{
sl@0
   282
	TInt index = iGenTypefaceFontsList->At(aTypefaceIndex);
sl@0
   283
	TInt type = iGenTypefaceFontsType->At(aTypefaceIndex);
sl@0
   284
sl@0
   285
	if (type == 0)
sl@0
   286
		iTypefaceStore->TypefaceSupport(aTypefaceSupport, index);
sl@0
   287
	else
sl@0
   288
		iFbsTypefaceStore->TypefaceSupport(aTypefaceSupport, index);
sl@0
   289
	}
sl@0
   290
sl@0
   291
EXPORT_C TInt CFbsDrvDevice::FontHeightInTwips(TInt aTypefaceIndex, TInt aHeightIndex) const
sl@0
   292
	{
sl@0
   293
	TInt index = iGenTypefaceFontsList->At(aTypefaceIndex);
sl@0
   294
	TInt type = iGenTypefaceFontsType->At(aTypefaceIndex);
sl@0
   295
sl@0
   296
	if (type == 0)
sl@0
   297
		return iTypefaceStore->FontHeightInTwips(index, aHeightIndex);
sl@0
   298
	else
sl@0
   299
		return iFbsTypefaceStore->FontHeightInTwips(index, aHeightIndex);
sl@0
   300
	}
sl@0
   301
sl@0
   302
EXPORT_C TInt CFbsDrvDevice::CreateContext(CGraphicsContext*& aGc)
sl@0
   303
	{
sl@0
   304
	__ASSERT_DEBUG(iControl, Panic(EPdrControlDoesNotExist));
sl@0
   305
	CPdrControl* control = (CPdrControl*)iControl;
sl@0
   306
	return control->CreateContext(aGc);
sl@0
   307
	}
sl@0
   308
sl@0
   309
EXPORT_C void CFbsDrvDevice::CreateControlL(CPrinterPort* aPrinterPort)
sl@0
   310
	{
sl@0
   311
	__ASSERT_ALWAYS(aPrinterPort, Panic(EPdrRequiresPrinterPort));
sl@0
   312
	__ASSERT_ALWAYS(!iControl, Panic(EPdrControlAlreadyExists));
sl@0
   313
	__ASSERT_DEBUG(iCurrentPageSpecInTwips.iPortraitPageSize.iWidth && iCurrentPageSpecInTwips.iPortraitPageSize.iHeight, Panic(EPdrPageSpecNotSet));
sl@0
   314
	iControl = CFbsDrvControl::NewL(this, aPrinterPort, *iStore, iModelInfo->iResourcesStreamId);
sl@0
   315
	}
sl@0
   316
sl@0
   317
/**
sl@0
   318
@deprecated Interface is deprecated because it is unsafe as it may leave. It is available for backward compatibility reasons only.
sl@0
   319
@see CFbsDrvDevice::SetModelL
sl@0
   320
*/
sl@0
   321
EXPORT_C TInt CFbsDrvDevice::SetModel(const TPrinterModelHeader& aModel, CStreamStore& aStore)
sl@0
   322
	{
sl@0
   323
	TInt ret = 0;
sl@0
   324
	TRAPD(errCode, ret=SetModelL(aModel, aStore));
sl@0
   325
	if(errCode != KErrNone)
sl@0
   326
		{
sl@0
   327
		return errCode;
sl@0
   328
		}
sl@0
   329
	return ret;
sl@0
   330
	}
sl@0
   331
sl@0
   332
EXPORT_C TInt CFbsDrvDevice::SetModelL(const TPrinterModelHeader& aModel, CStreamStore& aStore)
sl@0
   333
	{
sl@0
   334
	TInt ret = CPdrDevice::SetModel(aModel, aStore);
sl@0
   335
	if (ret == KErrNone)
sl@0
   336
		{
sl@0
   337
		iFbsTypefaceStore = CFbsTypefaceStore::NewL(this);
sl@0
   338
		LoadTypeFaceListL();
sl@0
   339
		}
sl@0
   340
	return ret;
sl@0
   341
	}
sl@0
   342
sl@0
   343
EXPORT_C TSize CFbsDrvDevice::KPixelSizeInTwips() const
sl@0
   344
	{
sl@0
   345
	return TSize(iModelInfo->iKPixelWidthInTwips, iModelInfo->iKPixelHeightInTwips);
sl@0
   346
	}
sl@0
   347
sl@0
   348
EXPORT_C void CFbsDrvDevice::Reserved_1()
sl@0
   349
	{
sl@0
   350
	}
sl@0
   351
sl@0
   352
EXPORT_C CFbsDrvControl* CFbsDrvControl::NewL(CPdrDevice* aPdrDevice, CPrinterPort* aPrinterPort, CStreamStore& aStore, TStreamId aResourcesStreamId)
sl@0
   353
	{
sl@0
   354
	CFbsDrvControl* control = new(ELeave) CFbsDrvControl(aPdrDevice, aPrinterPort);
sl@0
   355
	CleanupStack::PushL(control);
sl@0
   356
	control->ConstructL(aStore, aResourcesStreamId);
sl@0
   357
	CleanupStack::Pop();
sl@0
   358
	return control;
sl@0
   359
	}
sl@0
   360
sl@0
   361
EXPORT_C CFbsDrvControl::~CFbsDrvControl()
sl@0
   362
	{
sl@0
   363
	delete iScanLine;
sl@0
   364
	delete iCompressedScanLine;
sl@0
   365
	}
sl@0
   366
sl@0
   367
EXPORT_C CFbsDrvControl::CFbsDrvControl(CPdrDevice* aPdrDevice, CPrinterPort* aPrinterPort):
sl@0
   368
	CPdrControl(aPdrDevice, aPrinterPort),
sl@0
   369
	iScanLine(NULL),
sl@0
   370
	iCompressedScanLine(NULL)
sl@0
   371
	{
sl@0
   372
	__DECLARE_NAME(_S("CFbsDrvControl"));
sl@0
   373
	}
sl@0
   374
sl@0
   375
EXPORT_C void CFbsDrvControl::ConstructL(CStreamStore& aStore, TStreamId aResourcesStreamId)
sl@0
   376
	{
sl@0
   377
	CPdrControl::ConstructL(aStore, aResourcesStreamId);
sl@0
   378
	}
sl@0
   379
sl@0
   380
EXPORT_C void CFbsDrvControl::SetPageSizeL()
sl@0
   381
	{
sl@0
   382
	TCommandString des;
sl@0
   383
	des.Format(iResources->ResourceString(EPdrSetPageSize), iPdrDevice->CurrentPageSpecInTwips().iPortraitPageSize.iHeight / KTwipsPerInch);
sl@0
   384
	iPageBuffer->AddBytesL(des);
sl@0
   385
	}
sl@0
   386
sl@0
   387
/**
sl@0
   388
 @return ETrue if there are non-blank bytes in scanline. 
sl@0
   389
 */
sl@0
   390
EXPORT_C TBool CFbsDrvControl::TransformBuffer()
sl@0
   391
	{	
sl@0
   392
	TInt i;
sl@0
   393
	for (i = iScanLine->Length() - 1; (i >= 0) && (iScanLine->Des()[i] == 0xFF); i--)
sl@0
   394
		{
sl@0
   395
		}
sl@0
   396
	TInt length = i + 1;
sl@0
   397
	iScanLine->Des().SetLength(length);
sl@0
   398
	TUint8* p = (TUint8*)iScanLine->Des().Ptr();
sl@0
   399
	TUint8* pEnd = p + length;
sl@0
   400
	for (; p < pEnd; p++)
sl@0
   401
		{
sl@0
   402
		TInt byte1 = *p;
sl@0
   403
		TInt byte2 = 0;
sl@0
   404
		for (TInt j = 0; j < 8; j++)
sl@0
   405
			{
sl@0
   406
			byte2 = byte2 << 1;
sl@0
   407
			byte2 |= (byte1 & 1);
sl@0
   408
			byte1 = byte1 >> 1;
sl@0
   409
			}
sl@0
   410
		*p = (TUint8)~byte2; 
sl@0
   411
		}
sl@0
   412
	return (length > 0);	// returns ETrue if there are non-blank bytes in scanline
sl@0
   413
	}
sl@0
   414
sl@0
   415
/**
sl@0
   416
 @return ETrue if the scanline is compressed successfully. 
sl@0
   417
 */
sl@0
   418
EXPORT_C TBool CFbsDrvControl::CompressBuffer()
sl@0
   419
	{
sl@0
   420
	TInt length1 = iScanLine->Des().Length();
sl@0
   421
	TInt length2 = 0;
sl@0
   422
	TUint8* p1 = (TUint8*)iScanLine->Des().Ptr();
sl@0
   423
	TUint8* p2 = (TUint8*)iCompressedScanLine->Des().Ptr();
sl@0
   424
	TUint8 repeat;
sl@0
   425
	for (TInt i = 0; (i < length1) && (length2 < length1); i += repeat + 1)
sl@0
   426
		{
sl@0
   427
		TUint8 byte = *(p1++);
sl@0
   428
		for (repeat = 0; ((i + repeat + 1) < length1) && (byte == *p1) && (repeat < 255);)
sl@0
   429
			{
sl@0
   430
			repeat++;
sl@0
   431
			p1++;
sl@0
   432
			}
sl@0
   433
		length2++;
sl@0
   434
		if (length2 < length1)
sl@0
   435
			{
sl@0
   436
			*(p2++) = repeat;
sl@0
   437
			length2++;
sl@0
   438
			if (length2 < length1)
sl@0
   439
				*(p2++) = byte;
sl@0
   440
			}
sl@0
   441
		}
sl@0
   442
	iCompressedScanLine->Des().SetLength(length2);
sl@0
   443
	return (length2 < length1);   // returns ETrue if the scanline is compressed successfully
sl@0
   444
	}
sl@0
   445
sl@0
   446
/**
sl@0
   447
 This function is intentionally a dummy. It has to be implemented because
sl@0
   448
 of an inherited pure virtual but it should always be overload by any class
sl@0
   449
 that derives from it.
sl@0
   450
*/
sl@0
   451
EXPORT_C void CFbsDrvControl::OutputBandL()
sl@0
   452
	{
sl@0
   453
	// I should probably put an assert in here.
sl@0
   454
	if (IsGraphicsBand())
sl@0
   455
		{
sl@0
   456
		TRect bandrect = iBandedDevice->BandRect();
sl@0
   457
		TSize size = bandrect.Size();
sl@0
   458
		TCommandString des;
sl@0
   459
		TBool datainband = EFalse;
sl@0
   460
		TInt numscanlines = size.iHeight;
sl@0
   461
		if (iBandedDevice->BandingDirection() == EBandingRightToLeft)
sl@0
   462
			numscanlines = size.iWidth;
sl@0
   463
		for (TInt i = 0; i < numscanlines; i++)
sl@0
   464
			{
sl@0
   465
			TInt x = bandrect.iTl.iX;
sl@0
   466
			TInt y = bandrect.iTl.iY + i;
sl@0
   467
			TPtr8 ptr = iScanLine->Des();
sl@0
   468
			if (iBandedDevice->BandingDirection() == EBandingTopToBottom)
sl@0
   469
				iBandedDevice->BandBitmap()->GetScanLine(ptr, TPoint(0, i), size.iWidth, iPdrDevice->DisplayMode());
sl@0
   470
			else
sl@0
   471
				{
sl@0
   472
				iBandedDevice->BandBitmap()->GetVerticalScanLine(ptr, numscanlines - (i + 1), iPdrDevice->DisplayMode());
sl@0
   473
				x = bandrect.iBr.iX - i;
sl@0
   474
				y = bandrect.iTl.iY;
sl@0
   475
				}
sl@0
   476
			if (TransformBuffer() && !datainband)
sl@0
   477
				{
sl@0
   478
				MoveToL(TPoint(x, y));
sl@0
   479
				if (iBandedDevice->BandingDirection() == EBandingLeftToRight)
sl@0
   480
					des.Format(iResources->ResourceString(EPdrBitmapStart), EFbsPhysicalPageOrientation);
sl@0
   481
				else
sl@0
   482
					des.Format(iResources->ResourceString(EPdrBitmapStart), EFbsLogicalPageOrientation);
sl@0
   483
				iPageBuffer->AddBytesL(des);
sl@0
   484
				datainband = ETrue;
sl@0
   485
				}
sl@0
   486
			if (datainband)
sl@0
   487
				{
sl@0
   488
				TCommandString buf = iResources->ResourceString(EPdrScanLine);
sl@0
   489
				if (CompressBuffer())
sl@0
   490
					{
sl@0
   491
					des.Format(buf, EFbsRunLength, iCompressedScanLine->Des().Length());
sl@0
   492
					iPageBuffer->AddBytesL(des);
sl@0
   493
					iPageBuffer->AddBytesL(iCompressedScanLine->Des());
sl@0
   494
					}
sl@0
   495
				else
sl@0
   496
					{
sl@0
   497
					des.Format(buf, EFbsNone, iScanLine->Des().Length());
sl@0
   498
					iPageBuffer->AddBytesL(des);
sl@0
   499
					iPageBuffer->AddBytesL(iScanLine->Des());
sl@0
   500
					}
sl@0
   501
				}
sl@0
   502
			}
sl@0
   503
		iPageBuffer->AddBytesL(iResources->ResourceString(EPdrBitmapEnd));
sl@0
   504
sl@0
   505
		iPosition.iX = iPdrDevice->OffsetInPixels().iX;
sl@0
   506
		TInt numentries = iPageText->NumEntries();
sl@0
   507
		if(numentries)
sl@0
   508
			{
sl@0
   509
			CPageTextEntry* entry;
sl@0
   510
			for(TInt y = bandrect.iTl.iY; y <= bandrect.iBr.iY; y++)
sl@0
   511
				{
sl@0
   512
				for(TInt index = 0; (index < numentries); index++)
sl@0
   513
					{
sl@0
   514
					entry = (*iPageText)[index];
sl@0
   515
					TPoint drawPos = entry->iDrawPos;
sl@0
   516
					if(drawPos.iY == y)
sl@0
   517
						OutputTextL(drawPos, entry->iTextWidthInPixels, *(entry->iTextFormat), *(entry->iText));										 //!!
sl@0
   518
					}
sl@0
   519
				}
sl@0
   520
			}
sl@0
   521
		}
sl@0
   522
	}
sl@0
   523
sl@0
   524
EXPORT_C void CFbsDrvControl::Reserved_1()
sl@0
   525
	{
sl@0
   526
	}