Merge branch 'ryzom/ark/features' into atys

ryzom/sheets
Ulukyn 5 years ago
commit 6785217b3a

@ -112,6 +112,7 @@
#include "../entities.h" #include "../entities.h"
#include "../misc.h" #include "../misc.h"
#include "../gabarit.h" #include "../gabarit.h"
#include "../view.h"
#include "bot_chat_page_all.h" #include "bot_chat_page_all.h"
#include "bot_chat_page_ring_sessions.h" #include "bot_chat_page_ring_sessions.h"
@ -442,6 +443,8 @@ void CLuaIHMRyzom::RegisterRyzomFunctions(NLGUI::CLuaState &ls)
ls.registerFunc("enableModalWindow", enableModalWindow); ls.registerFunc("enableModalWindow", enableModalWindow);
ls.registerFunc("getPlayerPos", getPlayerPos); ls.registerFunc("getPlayerPos", getPlayerPos);
ls.registerFunc("getGroundAtMouse", getGroundAtMouse), ls.registerFunc("getGroundAtMouse", getGroundAtMouse),
ls.registerFunc("moveCam", moveCam),
ls.registerFunc("setCamMode", setCamMode),
ls.registerFunc("getMousePos", getMousePos), ls.registerFunc("getMousePos", getMousePos),
ls.registerFunc("getMouseDown", getMouseDown), ls.registerFunc("getMouseDown", getMouseDown),
ls.registerFunc("getMouseMiddleDown", getMouseMiddleDown), ls.registerFunc("getMouseMiddleDown", getMouseMiddleDown),
@ -588,6 +591,9 @@ void CLuaIHMRyzom::RegisterRyzomFunctions(NLGUI::CLuaState &ls)
LUABIND_FUNC(updateTooltipCoords), LUABIND_FUNC(updateTooltipCoords),
LUABIND_FUNC(isCtrlKeyDown), LUABIND_FUNC(isCtrlKeyDown),
LUABIND_FUNC(encodeURLUnicodeParam), LUABIND_FUNC(encodeURLUnicodeParam),
LUABIND_FUNC(encodeURLParam),
LUABIND_FUNC(encodeToHexa),
LUABIND_FUNC(decodeFromHexa),
LUABIND_FUNC(getPlayerLevel), LUABIND_FUNC(getPlayerLevel),
LUABIND_FUNC(getPlayerVpa), LUABIND_FUNC(getPlayerVpa),
LUABIND_FUNC(getPlayerVpb), LUABIND_FUNC(getPlayerVpb),
@ -1331,6 +1337,39 @@ int CLuaIHMRyzom::getGroundAtMouse(CLuaState &ls)
return 3; return 3;
} }
int CLuaIHMRyzom::moveCam(CLuaState &ls)
{
const char *funcName = "moveCam";
CLuaIHM::checkArgCount(ls, funcName, 3);
CLuaIHM::checkArgType(ls, funcName, 1, LUA_TNUMBER);
CLuaIHM::checkArgType(ls, funcName, 2, LUA_TNUMBER);
CLuaIHM::checkArgType(ls, funcName, 3, LUA_TNUMBER);
float x = (float)ls.toNumber(1);
float y = (float)ls.toNumber(2);
float z = (float)ls.toNumber(3);
CVector moves(x, y, z);
UserEntity->setCameraMoves(moves);
return 0;
}
int CLuaIHMRyzom::setCamMode(CLuaState &ls)
{
const char *funcName = "setCamMode";
CLuaIHM::checkArgCount(ls, funcName, 1);
bool aiMode = ls.toBoolean(1);
if(aiMode)
UserControls.mode(CUserControls::AIMode);
else
UserEntity->viewMode(UserEntity->viewMode());
return 0;
}
// *************************************************************************** // ***************************************************************************
int CLuaIHMRyzom::getPlayerPos(CLuaState &ls) int CLuaIHMRyzom::getPlayerPos(CLuaState &ls)
{ {
@ -3736,6 +3775,31 @@ std::string CLuaIHMRyzom::encodeURLUnicodeParam(const ucstring &text)
return convertToHTML(text.toUtf8()); return convertToHTML(text.toUtf8());
} }
// ***************************************************************************
std::string CLuaIHMRyzom::encodeURLParam(const string &text)
{
//H_AUTO(Lua_CLuaIHM_encodeURLUnicodeParam)
return convertToHTML(text);
}
// ***************************************************************************
std::string CLuaIHMRyzom::encodeToHexa(const string &text)
{
return toHexa(text);
}
// ***************************************************************************
std::string CLuaIHMRyzom::decodeFromHexa(const string &text)
{
string hexa;
fromHexa(text, hexa);
return hexa;
}
// *************************************************************************** // ***************************************************************************
sint32 CLuaIHMRyzom::getPlayerLevel() sint32 CLuaIHMRyzom::getPlayerLevel()
{ {

@ -232,6 +232,8 @@ private:
static std::string getRegionByAlias(uint32 alias); static std::string getRegionByAlias(uint32 alias);
static float getGroundZ(float x, float y); static float getGroundZ(float x, float y);
static int getGroundAtMouse(CLuaState &ls); static int getGroundAtMouse(CLuaState &ls);
static int moveCam(CLuaState &ls);
static int setCamMode(CLuaState &ls);
static int getMousePos(CLuaState &ls); static int getMousePos(CLuaState &ls);
static int getMouseDown(CLuaState &ls); static int getMouseDown(CLuaState &ls);
static int getMouseMiddleDown(CLuaState &ls); static int getMouseMiddleDown(CLuaState &ls);
@ -257,6 +259,10 @@ private:
// because it would be too easy to write a key recorder ...) // because it would be too easy to write a key recorder ...)
static bool isCtrlKeyDown(); static bool isCtrlKeyDown();
static std::string encodeURLUnicodeParam(const ucstring &text); static std::string encodeURLUnicodeParam(const ucstring &text);
static std::string encodeURLParam(const std::string &text);
static std::string encodeToHexa(const std::string &text);
static std::string decodeFromHexa(const std::string &text);
static sint32 getPlayerLevel(); // get max level among player skills (magi, combat, crafting ,foraging) static sint32 getPlayerLevel(); // get max level among player skills (magi, combat, crafting ,foraging)
static std::string getPlayerVpaHex(); static std::string getPlayerVpaHex();

@ -1411,8 +1411,23 @@ bool mainLoop()
// Update Camera Position/Orientation. // Update Camera Position/Orientation.
CVector currViewPos = View.currentViewPos(); CVector currViewPos = View.currentViewPos();
MainCam.setTransformMode(UTransformable::RotQuat); MainCam.setTransformMode(UTransformable::RotQuat);
CVector cameraMoves = UserEntity->getCameraMoves();
currViewPos.z += cameraMoves.z;
MainCam.setPos(currViewPos); MainCam.setPos(currViewPos);
MainCam.setRotQuat(View.currentViewQuat()); MainCam.setRotQuat(View.currentViewQuat());
if (cameraMoves.x)
{
CMatrix viewMatrix;
viewMatrix = MainCam.getMatrix();
viewMatrix.rotateZ(cameraMoves.x);
MainCam.setRotQuat(viewMatrix.getRot());
}
UserEntity->setCameraMoves(CVector(0, 0, 0));
if (StereoHMD) if (StereoHMD)
{ {
CMatrix camMatrix; CMatrix camMatrix;

@ -490,6 +490,16 @@ public:
return _LoginName; return _LoginName;
} }
CVector getCameraMoves()
{
return _CameraMoves;
}
void setCameraMoves(CVector moves)
{
_CameraMoves = moves;
}
protected: protected:
class CSpeedFactor : public NLMISC::ICDBNode::IPropertyObserver class CSpeedFactor : public NLMISC::ICDBNode::IPropertyObserver
{ {
@ -602,6 +612,8 @@ protected:
/// Time in MS when the User started beiing in collision with anything that avoid him to do an Action (and still is). /// Time in MS when the User started beiing in collision with anything that avoid him to do an Action (and still is).
sint64 _MoveToColStartTime; sint64 _MoveToColStartTime;
CVector _CameraMoves;
/// CSkill points observer /// CSkill points observer
class CSkillPointsObserver : public NLMISC::ICDBNode::IPropertyObserver class CSkillPointsObserver : public NLMISC::ICDBNode::IPropertyObserver

Loading…
Cancel
Save