Merge 1. Pull in cpp files in the performance enhanced Khronos RI OVG files which are newly added. I've ignored platform-specific cpp files for linux, macosx, and null operating systems because this local solution has its own platform glue (i.e. facility to target Bitmaps but no full windowing support). I've ignored sfEGLInterface.cpp because this is used as a bridge to go from EGL to Nokia's Platsim which offers an EGL service. That's not relevant to this implementation because this is ARM side code, not Intel side. I just left a comment to sfEGLInterface.cpp in case we need to pick up this later on. The current code compiles on winscw. Prior to this fix, the code works on winscw, and can launch the SVG tiger (tiger.exe). That takes about 20 seconds to render. I hope to always be able to show this icon on each commit, and the plan is for the render time to reduce with this series of submissions. On this commit, the tiger renders ok in 20 seconds.
// 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:
//
/**
@file
@publishedPartner
@prototype
*/
#ifndef SGRESOURCE_H
#define SGRESOURCE_H
#include <e32cmn.h>
#include <graphics/sgconst.h>
/**
@publishedPartner
@prototype
@deprecated
Set of static functions in the Graphics Resource API.
*/
class SgDriver
{
public:
IMPORT_C static TInt Open();
IMPORT_C static void Close();
IMPORT_C static TInt ResourceCount();
IMPORT_C static void AllocMarkStart();
IMPORT_C static void AllocMarkEnd(TInt aCount);
IMPORT_C static void SetAllocFail(RAllocator::TAllocFail aType, TInt aRate);
};
/**
@publishedPartner
@prototype
@deprecated
A user-defined graphics resource attribute. The Graphics Resource driver can attach
attributes defined by the user to a resource at creation time but does not interpret
them. The attributes cannot be changed after the resource has been created.
*/
struct TSgUserAttribute
{
/**
The globally unique identifier of the attribute.
*/
TUid iUid;
/**
The value of the attribute.
*/
TInt iValue;
};
/**
@publishedPartner
@prototype
@deprecated
This class is used to uniquely identify drawable resources. It represents an opaque
192-bit identifier that is unique across the system but not persistent.
*/
NONSHARABLE_CLASS(TSgDrawableId)
{
public:
inline TBool operator ==(const TSgDrawableId& aId) const;
inline TBool operator !=(const TSgDrawableId& aId) const;
public:
/**
The identifier stored as an array of six 32-bit integers. The contents have
no meaning to the user, except that all zeros represents a null identifier.
*/
TUint32 iId[6];
};
/**
@publishedPartner
@prototype
@deprecated
This constant represents the null drawable resource identifier, defined as 192 zero bits.
*/
const TSgDrawableId KSgNullDrawableId = {0, 0, 0, 0, 0, 0};
/**
@publishedPartner
@prototype
@deprecated
This globally unique identifier represents the handle type for instances of RSgDrawable.
*/
const TUid KSgDrawableTypeUid = {0x102858EB};
class MSgDrawableAdapter;
/**
@publishedPartner
@prototype
@deprecated
A handle to a reference-counted graphics resource that can be drawn in different
rendering pipelines, for example DirectGDI, OpenVG etc. Instances of RSgDrawable
allow access to drawable resources created using other APIs without knowing the
concrete type of the resource. Since drawable resources are reference-counted they
are guaranteed to exist while there are open handles referencing them.
A new RSgDrawable handle does not refer to a drawable resource until a successful
call to Open(). Before that point, the handle is said to be a null handle. Instances
of RSgDrawable can be shared among threads in the same process.
An RSgDrawable handle is said to be invalid if it is not null but it does not
reference an existing drawable resource. Copying an instance of RSgDrawable must
be done with extreme care, since it does not increment the reference count of the
referenced drawable resource and may therefore allow some RSgDrawable handle to
become invalid when the drawable resource is destroyed.
*/
NONSHARABLE_CLASS(RSgDrawable)
{
public:
IMPORT_C RSgDrawable();
IMPORT_C TInt Open(const TSgDrawableId& aId);
IMPORT_C TInt Open(const TSgDrawableId& aId, TUint32 aMode);
IMPORT_C void Close();
IMPORT_C const TSgDrawableId& Id() const;
IMPORT_C TBool IsNull() const;
IMPORT_C TUid DrawableType() const;
inline TUid HandleType() const;
template<class M> inline TInt GetInterface(M*& aInterfacePtr);
template<class M> inline TInt GetInterface(const M*& aInterfacePtr) const;
private:
IMPORT_C TInt GetInterface(TUid aInterfaceUid, TAny*& aInterfacePtr) const;
protected:
TUid iHandleType;
MSgDrawableAdapter* iImpl;
};
#include <graphics/sgresource.inl>
#endif // SGRESOURCE_H