appfw/apparchitecture/inc/APADBASE.H
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 15 Sep 2010 12:23:15 +0300
branchRCL_3
changeset 70 739cef680932
parent 0 2e3d3ce01487
permissions -rw-r--r--
Revision: 201035 Kit: 201036

// 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:
// apadbase.h
//

#ifndef __APADBASE_H__
#define __APADBASE_H__

#include <e32std.h>
#include <s32std.h>
#include <gdi.h>

// Base class for a wrapper for embedded CApaDocuments

/** The base class for the graphic representation of an embedded document.

An embedded document can be represented either as an icon or as a glass picture. 
Such a graphic representation is known as a door.

The class is intended for derivation.

@publishedAll 
@released
@see CApaDoor
@see CApaModelDoor */
class CApaDoorBase : public CPicture
	{
public:
	/** Defines the possible formats for the graphical representation of the embedded 
	document. */
	enum TFormat {
		/** The representation is an icon. */
		EIconic,
		/** The representation is a glass door. */
		EGlassDoor,
		/** The representation is a glass door but has been temporarily switched to an icon. */
		ETemporarilyIconic
		};
public:
	inline TFormat Format() const;
	inline TUid Source() const;
	inline void SetSource(TUid aSource);
public:	// from CPicture
	IMPORT_C TStreamId StoreL(CStreamStore& aStore) const;
	IMPORT_C void SetScaleFactor(TInt aScaleFactorWidth, TInt aScaleFactorHeight); 
	IMPORT_C void SetCropInTwips(const TMargins& aMargins); 
	IMPORT_C TPictureCapability Capability() const;
	IMPORT_C void GetCropInTwips(TMargins& aMargins) const; 
	IMPORT_C TInt ScaleFactorWidth() const; 
	IMPORT_C TInt ScaleFactorHeight() const; 
	IMPORT_C TBool LineBreakPossible(TUint aClass, TBool aBeforePicture, TBool aHaveSpaces) const;
	IMPORT_C TBool NativePixelSize(TSize& aPixelSize);
protected:
	IMPORT_C CApaDoorBase();
	IMPORT_C void ExternalizeBaseStreamL(CStreamStore& aStore,CStreamDictionary& aStreamDict)const;
	IMPORT_C TSize InternalizeBaseStreamL(const CStreamStore& aStore,const CStreamDictionary& aStreamDict); // returns current size in twips
private:
	IMPORT_C virtual void CApaDoorBase_Reserved1();
	IMPORT_C virtual void CApaDoorBase_Reserved2();
protected:
	/** Returns the size of the glass door, in twips.
	
	A concrete implementation of this function is provided by derived classes.
	
	@return The size of the glass door, in twips. 
	
	@publishedAll 
	@released */
	virtual TSize GlassDoorSize() const = 0;
protected:
	TFormat iFormat;
	TUid iSource; // foreign representation of a translated door (eg MS Word doc)
private:
	TInt iCApaDoorBase_Spare1;
	};

//
// inlines
//

/** Gets the current format of the representation of the embedded document.

@return The format for the representation of the embedded document. */
inline CApaDoorBase::TFormat CApaDoorBase::Format()const
	{ return iFormat; }

/** Gets the UID that identifies this door when the source originates on a non-Symbian 
OS device.

This is used by converters.

@return The UID for the non-Symbian OS source. For a source that originates 
on a Symbian OS phone, this is KNullUid. */
inline TUid CApaDoorBase::Source()const
	{ return iSource; }

/** Sets the UID that identifies this door when the source originates on a non-Symbian 
OS device.

This is used by converters.

@param aSource The UID for the non-Symbian OS source. For a source that originates 
on a Symbian OS phone, this is KNullUid. */
inline void CApaDoorBase::SetSource(TUid aSource)
	{ iSource=aSource; }

#endif	// __APADBASE_H__