graphicsdeviceinterface/screendriver/smomap/scnew.cpp
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) 2003-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:
// This module implements the functions that create the screen class depending
// on the screen type.
// Include files                                                   
// 
//

/**
 @file
*/
/********************************************************************/
#include <bitdraw.h>
#include "scdraw.h"
#include <hal.h>
#include "ScreenInfo.h"
#include <graphics/gdi/gdiconsts.h>

/**
Creates an instance of CFbsDrawDevice class.
@param aScreenNo Screen number
@param aDispMode Display mode
@param aScreenInfo Screen parameters: video memory address and screen size
@return A pointer to the created CFbsDrawDevice object
@leave System-wide error code including KErrNoMemory
@internalComponent
*/
static CFbsDrawDevice* CreateInstanceL(TInt aScreenNo,
									   TDisplayMode aDispMode,
									   const TScreenInfo& aScreenInfo)
	{
	CFbsDrawDevice* drawDevice = NULL;

	TInt bpp;
	if(HAL::Get(aScreenNo, HALData::EDisplayMode, bpp) != KErrNone)
		{
		User::Leave(KErrNotSupported);
		}
	if(HAL::Get(aScreenNo, HALData::EDisplayBitsPerPixel, bpp) != KErrNone)
		{
		User::Leave(KErrNotSupported);
		}
   
    //Switch the display mode, call the construtor of the class defined
    //in the ScmonXX.cpp or SccolXX.cpp file.
	switch(aDispMode)
		{
	case EColor256: // 8 Bpp color mode
		if(bpp == 8)
			{
			drawDevice = new (ELeave) CDrawEightBppScreenBitmapColor;
			CleanupStack::PushL(drawDevice) ;
			User::LeaveIfError(((CDrawEightBppScreenBitmapColor*)drawDevice)->ConstructScreenL(
                                                            aScreenNo,
															aScreenInfo.iAddress, 
															aScreenInfo.iSize));
			}
		else
			{
			User::Leave(KErrNotSupported);
			}
		break;

	case EColor64K: // 16 Bpp color mode
		if(bpp == 16)
			{
			drawDevice = new (ELeave) CDrawSixteenBppScreenBitmap;
			CleanupStack::PushL(drawDevice);
			User::LeaveIfError(((CDrawSixteenBppScreenBitmap*)drawDevice)->ConstructScreenL(
                                                            aScreenNo,
															aScreenInfo.iAddress, 
															aScreenInfo.iSize));
			}
		else
			{
			User::Leave(KErrNotSupported);
			}
		break;
   
   	case EColor16MU: // 24 unpacked Bpp color mode
		if((bpp == 24 || bpp == 32) && aDispMode == CFbsDrawDevice::DisplayMode16M()) 	//there is some "ambiguity" about 24 and 32 bit modes... 
	//They are both byte per color component, and both actually have 32 bits per pixel memory use.
			{
			drawDevice = new (ELeave) CDrawUTwentyFourBppScreenBitmap;
			CleanupStack::PushL(drawDevice);
			User::LeaveIfError(((CDrawUTwentyFourBppScreenBitmap*)drawDevice)->ConstructScreenL(
                                                            aScreenNo,
															aScreenInfo.iAddress, 
															aScreenInfo.iSize));
			}
		else
			{
			User::Leave(KErrNotSupported);
			}
		break;
	
	 case EColor16MA: // 32 Bpp color mode
		if((bpp == 24 || bpp == 32) && aDispMode == CFbsDrawDevice::DisplayMode16M())  	//there is some "ambiguity" about 24 and 32 bit modes... 
	//They are both byte per color component, and both actually have 32 bits per pixel memory use.
			{
			drawDevice = new (ELeave) CDrawThirtyTwoBppScreenBitmapAlpha;
			CleanupStack::PushL(drawDevice);
			User::LeaveIfError(((CDrawThirtyTwoBppScreenBitmapAlpha*)drawDevice)->ConstructScreenL(
                                                            aScreenNo,
															aScreenInfo.iAddress, 
															aScreenInfo.iSize));
			}
		else
			{
			User::Leave(KErrNotSupported);
			}
		break;
		
	case EColor16MAP: // 32 Bpp color mode
		if((bpp == 24 || bpp == 32) && aDispMode == CFbsDrawDevice::DisplayMode16M()) 	//there is some "ambiguity" about 24 and 32 bit modes... 
	//They are both byte per color component, and both actually have 32 bits per pixel memory use.
			{
			drawDevice = new (ELeave) CDrawThirtyTwoBppScreenBitmapAlphaPM;
			CleanupStack::PushL(drawDevice);
			User::LeaveIfError(((CDrawThirtyTwoBppScreenBitmapAlphaPM*)drawDevice)->ConstructScreenL(
                                                            aScreenNo,
															aScreenInfo.iAddress, 
															aScreenInfo.iSize));
			}
		else
			{
			User::Leave(KErrNotSupported);
			}
		break;

	default:
		User::Leave(KErrNotSupported);
		}

	CleanupStack::Pop(drawDevice);
    return drawDevice;
	}


/********************************************************************/
/*  Implementation of CFbsDrawDevice class                          */
/********************************************************************/

/**
This function calls the correct constructor in function of the display mode.
@param aInfo, Structure of the LCD info
@param aDispMode, display mode   
@return A pointer to just created screen device, which implements CFbsDrawDevice interface
@deprecated Use CFbsDrawDevice::NewScreenDeviceL(TInt aScreenNo, TDisplayMode aDispMode)
*/
EXPORT_C CFbsDrawDevice* CFbsDrawDevice::NewScreenDeviceL(TScreenInfoV01 aInfo, TDisplayMode aDispMode)
	{
    __ASSERT_ALWAYS(aInfo.iScreenAddressValid, Panic(EScreenDriverPanicInvalidWindowHandle));
	TScreenInfo screenInfo(aInfo.iScreenAddress, aInfo.iScreenSize);
	return ::CreateInstanceL(KDefaultScreenNo, aDispMode, screenInfo);
	}

/**
Creates a new screen device instance, which implements CFbsDrawDevice interface.
The method has to be implemented for each type of supported video hardware.
@param aScreenNo Screen number
@param aDispMode Requested display mode
@return A pointer to just created screen device, which implements CFbsDrawDevice interface
@leave KErrNoMemory Not enough memory
	   KErrNotSupported The requested screen device type is not supported
*/
EXPORT_C CFbsDrawDevice* CFbsDrawDevice::NewScreenDeviceL(TInt aScreenNo,
														  TDisplayMode aDispMode)
	{
	TInt address = 0, width = 0, height = 0;
	User::LeaveIfError(HAL::Get(aScreenNo, HALData::EDisplayMemoryAddress, address));
	User::LeaveIfError(HAL::Get(aScreenNo, HALData::EDisplayXPixels, width));
	User::LeaveIfError(HAL::Get(aScreenNo, HALData::EDisplayYPixels, height));
	__ASSERT_ALWAYS(width > 0 && height > 0 && address != 0, Panic(EScreenDriverPanicInvalidHalValue));
	TScreenInfo screenInfo(reinterpret_cast <TAny*> (address), TSize(width, height));
	return ::CreateInstanceL(aScreenNo, aDispMode, screenInfo);
	}

/**
Depending on the current graphics hardware this 
will return one of the 16M video modes defined in
TDisplayMode, or ENone if a 16M video mode is not supported.
@see TDisplayMode
@return	a 16M display mode or ENone.
*/
EXPORT_C TDisplayMode CFbsDrawDevice::DisplayMode16M()
	{
//	return ENone;
	return EColor16MA;
	}