2011-02-22 10:33:14 +00:00
|
|
|
/*
|
2008-04-16 22:40:48 +00:00
|
|
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
2008-04-16 22:40:48 +00:00
|
|
|
* of the License, or (at your option) any later version.
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
2010-02-12 13:34:04 +00:00
|
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* The Original Code is: all of this file.
|
|
|
|
*
|
|
|
|
* Contributor(s): none yet.
|
|
|
|
*
|
2008-04-16 22:40:48 +00:00
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
2002-10-12 11:37:38 +00:00
|
|
|
*/
|
2011-02-22 10:33:14 +00:00
|
|
|
|
|
|
|
/** \file SCA_ILogicBrick.h
|
|
|
|
* \ingroup gamelogic
|
|
|
|
*/
|
|
|
|
|
2012-02-23 10:41:31 +00:00
|
|
|
#ifndef __SCA_ILOGICBRICK_H__
|
|
|
|
#define __SCA_ILOGICBRICK_H__
|
2002-10-12 11:37:38 +00:00
|
|
|
|
|
|
|
#include "Value.h"
|
|
|
|
#include "SCA_IObject.h"
|
|
|
|
#include "BoolValue.h"
|
2011-05-06 20:18:42 +00:00
|
|
|
#include "CTR_Map.h"
|
|
|
|
#include "CTR_HashedPtr.h"
|
2002-11-25 11:16:17 +00:00
|
|
|
|
2009-11-15 23:58:56 +00:00
|
|
|
class NG_NetworkScene;
|
|
|
|
class SCA_IScene;
|
|
|
|
|
2002-10-12 11:37:38 +00:00
|
|
|
class SCA_ILogicBrick : public CValue
|
|
|
|
{
|
2011-11-06 01:39:36 +00:00
|
|
|
Py_Header
|
2004-06-04 03:00:13 +00:00
|
|
|
protected:
|
2002-10-12 11:37:38 +00:00
|
|
|
SCA_IObject* m_gameobj;
|
|
|
|
int m_Execute_Priority;
|
|
|
|
int m_Execute_Ueber_Priority;
|
|
|
|
|
|
|
|
bool m_bActive;
|
|
|
|
CValue* m_eventval;
|
|
|
|
STR_String m_text;
|
|
|
|
STR_String m_name;
|
|
|
|
//unsigned long m_drawcolor;
|
|
|
|
void RegisterEvent(CValue* eventval);
|
|
|
|
void RemoveEvent();
|
|
|
|
CValue* GetEvent();
|
|
|
|
|
|
|
|
public:
|
2009-06-28 11:22:26 +00:00
|
|
|
SCA_ILogicBrick(SCA_IObject* gameobj);
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual ~SCA_ILogicBrick();
|
|
|
|
|
|
|
|
void SetExecutePriority(int execute_Priority);
|
|
|
|
void SetUeberExecutePriority(int execute_Priority);
|
|
|
|
|
2009-06-08 20:08:19 +00:00
|
|
|
SCA_IObject* GetParent() { return m_gameobj; }
|
|
|
|
|
2002-10-12 11:37:38 +00:00
|
|
|
virtual void ReParent(SCA_IObject* parent);
|
2011-05-06 20:18:42 +00:00
|
|
|
virtual void Relink(CTR_Map<CTR_HashedPtr, void*> *obj_map);
|
2009-03-11 22:11:52 +00:00
|
|
|
virtual void Delete() { Release(); }
|
2002-10-12 11:37:38 +00:00
|
|
|
|
|
|
|
// act as a BoolValue (with value IsPositiveTrigger)
|
|
|
|
virtual CValue* Calc(VALUE_OPERATOR op, CValue *val);
|
|
|
|
virtual CValue* CalcFinal(VALUE_DATA_TYPE dtype, VALUE_OPERATOR op, CValue *val);
|
|
|
|
|
|
|
|
virtual const STR_String & GetText();
|
2009-04-20 15:06:46 +00:00
|
|
|
virtual double GetNumber();
|
2009-06-08 20:08:19 +00:00
|
|
|
virtual STR_String& GetName();
|
|
|
|
virtual void SetName(const char *);
|
2002-10-12 11:37:38 +00:00
|
|
|
|
2009-06-08 20:08:19 +00:00
|
|
|
bool IsActive()
|
|
|
|
{
|
|
|
|
return m_bActive;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetActive(bool active)
|
|
|
|
{
|
|
|
|
m_bActive=active;
|
|
|
|
}
|
|
|
|
|
|
|
|
// insert in a QList at position corresponding to m_Execute_Priority
|
|
|
|
void InsertActiveQList(SG_QList& head)
|
|
|
|
{
|
|
|
|
SG_QList::iterator<SCA_ILogicBrick> it(head);
|
2012-06-17 09:58:26 +00:00
|
|
|
for (it.begin(); !it.end() && m_Execute_Priority > (*it)->m_Execute_Priority; ++it);
|
2009-06-08 20:08:19 +00:00
|
|
|
it.add_back(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
// insert in a QList at position corresponding to m_Execute_Priority
|
|
|
|
// inside a longer list that contains elements of other objects.
|
|
|
|
// Sorting is done only between the elements of the same object.
|
|
|
|
// head is the head of the combined list
|
|
|
|
// current points to the first element of the object in the list, NULL if none yet
|
|
|
|
void InsertSelfActiveQList(SG_QList& head, SG_QList** current)
|
|
|
|
{
|
|
|
|
if (!*current)
|
|
|
|
{
|
|
|
|
// first element can be put anywhere
|
|
|
|
head.QAddBack(this);
|
|
|
|
*current = this;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// note: we assume current points actually to one o our element, skip the tests
|
|
|
|
SG_QList::iterator<SCA_ILogicBrick> it(head,*current);
|
|
|
|
if (m_Execute_Priority <= (*it)->m_Execute_Priority)
|
|
|
|
{
|
|
|
|
// this element comes before the first
|
|
|
|
*current = this;
|
|
|
|
}
|
2012-06-17 09:58:26 +00:00
|
|
|
else {
|
|
|
|
for (++it; !it.end() && (*it)->m_gameobj == m_gameobj && m_Execute_Priority > (*it)->m_Execute_Priority; ++it);
|
2009-06-08 20:08:19 +00:00
|
|
|
}
|
|
|
|
it.add_back(this);
|
|
|
|
}
|
2002-10-12 11:37:38 +00:00
|
|
|
|
|
|
|
virtual bool LessComparedTo(SCA_ILogicBrick* other);
|
|
|
|
|
2009-11-15 23:58:56 +00:00
|
|
|
/* runtime variable, set when Triggering the python controller */
|
2002-10-12 11:37:38 +00:00
|
|
|
static class SCA_LogicManager* m_sCurrentLogicManager;
|
|
|
|
|
|
|
|
|
2009-11-15 23:58:56 +00:00
|
|
|
/* for moving logic bricks between scenes */
|
2012-01-16 05:27:11 +00:00
|
|
|
virtual void Replace_IScene(SCA_IScene *val) {}
|
|
|
|
virtual void Replace_NetworkScene(NG_NetworkScene *val) {}
|
2009-11-15 23:58:56 +00:00
|
|
|
|
2010-10-31 04:11:39 +00:00
|
|
|
#ifdef WITH_PYTHON
|
2002-10-12 11:37:38 +00:00
|
|
|
// python methods
|
2009-04-20 15:06:46 +00:00
|
|
|
|
|
|
|
static PyObject* pyattr_get_owner(void *self_v, const KX_PYATTRIBUTE_DEF *attrdef);
|
2002-10-12 11:37:38 +00:00
|
|
|
|
2009-01-02 17:43:56 +00:00
|
|
|
// check that attribute is a property
|
|
|
|
static int CheckProperty(void *self, const PyAttributeDef *attrdef);
|
|
|
|
|
2002-10-12 11:37:38 +00:00
|
|
|
enum KX_BOOL_TYPE {
|
|
|
|
KX_BOOL_NODEF = 0,
|
|
|
|
KX_TRUE,
|
|
|
|
KX_FALSE,
|
|
|
|
KX_BOOL_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/* Some conversions to go with the bool type. */
|
|
|
|
/** Convert a KX_TRUE, KX_FALSE in Python to a c++ value. */
|
|
|
|
bool PyArgToBool(int boolArg);
|
|
|
|
|
|
|
|
/** Convert a a c++ value to KX_TRUE, KX_FALSE in Python. */
|
2012-09-16 04:58:18 +00:00
|
|
|
PyObject *BoolToPyArg(bool);
|
2002-10-12 11:37:38 +00:00
|
|
|
|
2010-10-31 04:11:39 +00:00
|
|
|
#endif // WITH_PYTHON
|
2009-09-29 21:42:40 +00:00
|
|
|
|
2002-10-12 11:37:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|
2002-10-30 02:07:20 +00:00
|
|
|
|