graphicsresourceservices/graphicsresourceimplementation/src/sgimage.cpp
changeset 36 01a6848ebfd7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/graphicsresourceservices/graphicsresourceimplementation/src/sgimage.cpp	Fri Apr 16 16:21:04 2010 +0300
@@ -0,0 +1,226 @@
+// Copyright (c) 2007-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:
+// Graphics Resource - image implementation
+//
+
+#include "sgdriver.h"
+
+EXPORT_C TInt RSgImage::Create(const TSgImageInfo& aInfo, const TAny* aDataAddress, TInt aDataStride, const TSgAttributeArrayBase* aAttributes)
+	{
+	if (iImpl)
+		{
+		return KErrInUse;
+		}
+	__ASSERT_ALWAYS(gPls.iDriver, Panic(ESgPanicNoDriver));
+	return gPls.iDriver->CreateImage(aInfo, aDataAddress, aDataStride, aAttributes, iImpl);
+	}
+
+EXPORT_C TInt RSgImage::Create(const TSgImageInfo& aInfo, const RSgImage& aImage, const TSgAttributeArrayBase* aAttributes)
+	{
+	if (iImpl)
+		{
+		return KErrInUse;
+		}
+	__ASSERT_ALWAYS(gPls.iDriver, Panic(ESgPanicNoDriver));
+	return gPls.iDriver->CreateImage(aInfo, static_cast<XSgImage*>(aImage.iImpl), aAttributes, iImpl);
+	}
+
+EXPORT_C TInt RSgImage::GetInfo(TSgImageInfo& aInfo) const
+	{
+	if (!iImpl)
+		{
+		return KErrBadHandle;
+		}
+	__ASSERT_ALWAYS(gPls.iDriver, Panic(ESgPanicNoDriver));
+	__ASSERT_ALWAYS(gPls.iDriver->CheckImage(iImpl), Panic(ESgPanicBadDrawableHandle));
+	static_cast<XSgImage*>(iImpl)->GetInfo(aInfo);
+	return KErrNone;
+	}
+
+EXPORT_C TInt RSgImage::GetAttribute(TUid aUid, TInt& aValue) const
+	{
+	if (!iImpl)
+		{
+		return KErrBadHandle;
+		}
+	__ASSERT_ALWAYS(gPls.iDriver, Panic(ESgPanicNoDriver));
+	__ASSERT_ALWAYS(gPls.iDriver->CheckImage(iImpl), Panic(ESgPanicBadDrawableHandle));
+	return static_cast<XSgImage*>(iImpl)->GetAttribute(aUid, aValue);
+	}
+
+EXPORT_C TInt RSgImage::GetPixelFormats(TUint32 aUsage, RArray<TInt>& aPixelFormats, const TSgAttributeArrayBase* aAttributes)
+	{
+	static const TInt KSupportedPixelFormats[] =
+		{
+		ESgPixelFormatA_8,
+		ESgPixelFormatRGB_565,
+		ESgPixelFormatXRGB_8888,
+		ESgPixelFormatARGB_8888,
+		ESgPixelFormatARGB_8888_PRE
+		};
+	static const TInt KNumSupportedPixelFormats = sizeof(KSupportedPixelFormats) / sizeof(TInt);
+	if (aUsage == 0 || aPixelFormats.Count() != 0)
+		{
+		return KErrArgument;
+		}
+	if (aAttributes)
+		{
+		return KErrNotSupported;
+		}
+	if (aUsage & ~KSgUsageAll)
+		{
+		return KErrNone;
+		}
+	_LIT(KLibOpenVg, "libOpenVG.dll");
+	_LIT(KLibOpenGles, "libGLESv1_CM.dll");
+	_LIT(KLibOpenGles2, "libGLESv2.dll");
+	RLibrary lib;
+	if (aUsage & (ESgUsageBitOpenVgImage | ESgUsageBitOpenVgSurface))
+		{
+		if (lib.Load(KLibOpenVg) != KErrNone)
+			{
+			return KErrNone;
+			}
+		lib.Close();
+		}
+	if (aUsage & (ESgUsageBitOpenGlesTexture2D | ESgUsageBitOpenGlesSurface))
+		{
+		if (lib.Load(KLibOpenGles) != KErrNone)
+			{
+			return KErrNone;
+			}
+		lib.Close();
+		}
+	if (aUsage & (ESgUsageBitOpenGles2Texture2D | ESgUsageBitOpenGles2Surface))
+		{
+		if (lib.Load(KLibOpenGles2) != KErrNone)
+			{
+			return KErrNone;
+			}
+		lib.Close();
+		}
+	TInt err = KErrNone;
+	for (TInt i = 0; i < KNumSupportedPixelFormats; ++i)
+		{
+		if (KSupportedPixelFormats[i] == ESgPixelFormatA_8 && (aUsage & KSgUsageAllSurfaceTypes))
+			{
+			continue;
+			}
+		err = aPixelFormats.Append(KSupportedPixelFormats[i]);
+		if (err != KErrNone)
+			{
+			break;
+			}
+		}
+	return err;
+	}
+
+XSgImage::XSgImage(TSgDrawableId aId, TUint32 aAttribs, const TSgImageMetaData& aMetaData, TAny* aDataAddress, TInt aDataStride)
+	: iRefCount(1), iId(aId), iInfo(aMetaData.iSizeInPixels, aMetaData.iPixelFormat, aAttribs & KSgUsageBitMask),
+	  iDataAddress(aDataAddress), iDataStride(aDataStride)
+	{
+	}
+
+XSgImage::~XSgImage()
+	{
+	__ASSERT_DEBUG(iRefCount == 0, Panic(ESgPanicBadRefCount));
+	}
+
+TInt XSgImage::Open()
+	{
+	if (User::SafeInc(iRefCount) == 0)
+		{
+		return KErrNotFound;
+		}
+	return KErrNone;
+	}
+
+void XSgImage::Close()
+	{
+	if (User::SafeDec(iRefCount) == 1)
+		{
+		gPls.iDriver->DeleteImage(this);
+		}
+	}
+
+TInt XSgImage::RefCount() const
+	{
+	return iRefCount;
+	}
+
+TSgDrawableId XSgImage::Id() const
+	{
+	return iId;
+	}
+
+TUid XSgImage::DrawableType() const
+	{
+	return KSgImageTypeUid;
+	}
+
+TInt XSgImage::GetInterface(TUid aInterfaceUid, TAny*& aInterfacePtr)
+	{
+	if (aInterfaceUid == KNullUid)
+		{
+		return KErrArgument;
+		}
+	if (aInterfaceUid.iUid == MSgImage_Sw::EInterfaceUid)
+		{
+		aInterfacePtr = static_cast<MSgImage_Sw*>(this);
+		return KErrNone;
+		}
+	return KErrExtensionNotSupported;
+	}
+
+void XSgImage::GetInfo(TSgImageInfo& aInfo) const
+	{
+	aInfo = iInfo;
+	}
+
+TInt XSgImage::GetAttribute(TUid aUid, TInt& /*aValue*/) const
+	{
+	if (aUid == KNullUid)
+		{
+		return KErrArgument;
+		}
+	return KErrNotSupported;
+	}
+
+TInt XSgImage::Compare(const XSgImage& aImage1, const XSgImage& aImage2)
+	{
+	return Compare(&aImage1.iId, aImage2);
+	}
+
+TInt XSgImage::Compare(const TSgDrawableId* aId, const XSgImage& aImage)
+	{
+	if (aId->iId > aImage.iId.iId)
+		{
+		return 1;
+		}
+	if (aId->iId < aImage.iId.iId)
+		{
+		return -1;
+		}
+	return 0;
+	}
+
+TAny* XSgImage::DataAddress() const
+	{
+	return iDataAddress;
+	}
+
+TInt XSgImage::DataStride() const
+	{
+	return iDataStride;
+	}