Added GLES 1.x spinning cube-rendering code to eglbringuptest
The coordinate, color and index data are uploaded to server-side
buffers by the CGLES1Cube::KhrSetup function. CGLES1Cube::KhrPaint
just sets the view matrix and issues a draw command.
Which demo to display can be selected by passing its name on the
command line, e.g.
eglbringuptest vgline
eglbringuptest gles1cube
If no name is provided, the application defaults to vgline.
/*
* Copyright (c) 2005-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:
*
*/
#include "T_DataBlankWindow.h"
/*@{*/
_LIT(KDataClassname, "RBlankWindow");
//Commands
_LIT(KCmdnew, "new");
_LIT(KCmdDestructor, "~");
_LIT(KCmdConstruct, "Construct");
_LIT(KCmdSetColor, "SetColor");
_LIT(KCmdSetSize, "SetSize");
_LIT(KCmdSetExtent, "SetExtent");
// Fields
_LIT(KFldColor, "color");
_LIT(KFldHandle, "handle");
_LIT(KFldParent, "parent");
_LIT(KFldPoint, "point");
_LIT(KFldSize, "size");
_LIT(KFldWs, "ws");
/// Logging
_LIT(KLogError, "Error=%d");
_LIT(KLogMissingParameter, "Missing parameter '%S'");
/*@}*/
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CT_DataBlankWindow* CT_DataBlankWindow::NewL()
{
CT_DataBlankWindow* ret=new (ELeave) CT_DataBlankWindow();
CleanupStack::PushL(ret);
ret->ConstructL();
CleanupStack::Pop(ret);
return ret;
}
CT_DataBlankWindow::CT_DataBlankWindow()
: CT_DataWindowBase()
, iBlankWindow(NULL)
{
}
void CT_DataBlankWindow::ConstructL()
{
}
CT_DataBlankWindow::~CT_DataBlankWindow()
{
DestroyData();
}
void CT_DataBlankWindow::SetObjectL(TAny* aAny)
{
DestroyData();
iBlankWindow = static_cast<RBlankWindow*> (aAny);
}
void CT_DataBlankWindow::DisownObjectL()
{
iBlankWindow = NULL;
}
void CT_DataBlankWindow::DestroyData()
{
delete iBlankWindow;
iBlankWindow=NULL;
}
RWindowBase* CT_DataBlankWindow::GetWindowBase() const
{
return iBlankWindow;
}
/**
* Process a command read from the ini file
*
* @param aCommand the command to process
* @param aSection the entry in the ini file requiring the command to be processed
* @param aAsyncErrorIndex index of command. used for async calls
*
* @return ETrue if the command is processed
*/
TBool CT_DataBlankWindow::DoCommandL(const TTEFFunction& aCommand, const TTEFSectionName& aSection, const TInt aAsyncErrorIndex)
{
TBool ret = ETrue;
if ( aCommand==KCmdDestructor )
{
DestroyData();
}
else if ( aCommand==KCmdnew || aCommand==KDataClassname )
{
DoCmdnewL(aSection);
}
else if ( aCommand==KCmdConstruct )
{
DoCmdConstructL(aSection);
}
else if ( aCommand==KCmdSetColor )
{
DoCmdSetColor(aSection);
}
else if ( aCommand==KCmdSetSize )
{
DoCmdSetSize(aSection);
}
else if ( aCommand==KCmdSetExtent )
{
DoCmdSetExtent(aSection);
}
else
{
ret=CT_DataWindowBase::DoCommandL(aCommand, aSection, aAsyncErrorIndex);
}
return ret;
}
void CT_DataBlankWindow::DoCmdnewL(const TDesC& aSection)
{
DestroyData();
// Get test data for command input parameter(s)
TPtrC wsName;
RWsSession* ws=NULL;
if ( GetStringFromConfig(aSection, KFldWs, wsName) )
{
ws = static_cast<RWsSession*>(GetDataObjectL(wsName));
}
TInt err;
if ( ws != NULL )
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute new RBlankWindow(RWsSession)"));
TRAP( err, iBlankWindow = new (ELeave) RBlankWindow(*ws) );
}
else
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute new RBlankWindow()"));
TRAP( err, iBlankWindow = new (ELeave) RBlankWindow() );
}
if ( err != KErrNone )
{
ERR_PRINTF2(KLogError, err);
SetError(err);
}
// No command output parameter to display and check
}
void CT_DataBlankWindow::DoCmdConstructL(const TDesC& aSection)
{
TBool dataOk=ETrue;
// Get test data for command input parameter(s)
TPtrC parentName;
RWindowTreeNode* parent=NULL;
if ( GetStringFromConfig(aSection, KFldParent, parentName) )
{
parent = static_cast<RWindowTreeNode*>(GetDataObjectL(parentName));
}
if ( parent==NULL )
{
dataOk=EFalse;
ERR_PRINTF2(KLogMissingParameter, &KFldParent);
SetBlockResult(EFail);
}
TInt datHandle;
if ( !GetIntFromConfig(aSection, KFldHandle, datHandle) )
{
dataOk=EFalse;
ERR_PRINTF2(KLogMissingParameter, &KFldHandle);
SetBlockResult(EFail);
}
if ( dataOk )
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute Construct(RWindowTreeNode, TUint32)"));
TInt returnCode = iBlankWindow->Construct(*parent, datHandle);
// Check the command return code, if !=KErrNone then stop this command
if ( returnCode != KErrNone )
{
ERR_PRINTF2(KLogError, returnCode);
SetError(returnCode);
}
// No command output parameter to display and check
}
}
void CT_DataBlankWindow::DoCmdSetColor(const TDesC& aSection)
{
// Get test data for command input parameter(s)
TRgb datColor;
if ( GetRgbFromConfig(aSection, KFldColor, datColor) )
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute SetColor(TRgb)"));
iBlankWindow->SetColor(datColor);
}
else
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute SetColor()"));
iBlankWindow->SetColor();
}
}
void CT_DataBlankWindow::DoCmdSetSize(const TDesC& aSection)
{
// Get test data for command input parameter(s)
TSize datSize;
if ( !GetSizeFromConfig(aSection, KFldSize, datSize) )
{
ERR_PRINTF2(KLogMissingParameter, &KFldSize);
SetBlockResult(EFail);
}
else
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute SetSize(TSize)"));
iBlankWindow->SetSize(datSize);
}
}
void CT_DataBlankWindow::DoCmdSetExtent(const TDesC& aSection)
{
TBool dataOk=ETrue;
// Get test data for command input parameter(s)
TPoint datPoint;
if ( !GetPointFromConfig(aSection, KFldPoint, datPoint) )
{
dataOk=EFalse;
ERR_PRINTF2(KLogMissingParameter, &KFldPoint);
SetBlockResult(EFail);
}
TSize datSize;
if ( !GetSizeFromConfig(aSection, KFldSize, datSize) )
{
dataOk=EFalse;
ERR_PRINTF2(KLogMissingParameter, &KFldSize);
SetBlockResult(EFail);
}
if ( dataOk )
{
// Execute command and log parameters
INFO_PRINTF1(_L("execute SetExtent(TPoint, TSize)"));
iBlankWindow->SetExtent(datPoint, datSize);
}
}