mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-03-29 19:36:43 +00:00
Merge remote-tracking branch 'greye/player-model'
This commit is contained in:
commit
409d15576b
5 changed files with 87 additions and 19 deletions
|
@ -461,10 +461,10 @@ void CharacterCreation::onRaceDialogBack()
|
||||||
if (mRaceDialog)
|
if (mRaceDialog)
|
||||||
{
|
{
|
||||||
const ESM::NPC &data = mRaceDialog->getResult();
|
const ESM::NPC &data = mRaceDialog->getResult();
|
||||||
mPlayerRaceId = data.mId;
|
mPlayerRaceId = data.mRace;
|
||||||
if (!mPlayerRaceId.empty()) {
|
if (!mPlayerRaceId.empty()) {
|
||||||
MWBase::Environment::get().getMechanicsManager()->setPlayerRace(
|
MWBase::Environment::get().getMechanicsManager()->setPlayerRace(
|
||||||
data.mId,
|
data.mRace,
|
||||||
data.isMale(),
|
data.isMale(),
|
||||||
data.mHead,
|
data.mHead,
|
||||||
data.mHair
|
data.mHair
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
|
|
||||||
#include <boost/algorithm/string.hpp>
|
#include <boost/algorithm/string.hpp>
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
|
#include <boost/format.hpp>
|
||||||
|
|
||||||
#include "../mwworld/esmstore.hpp"
|
#include "../mwworld/esmstore.hpp"
|
||||||
|
|
||||||
|
@ -108,6 +109,16 @@ void RaceDialog::open()
|
||||||
MWBase::Environment::get().getWorld ()->setupExternalRendering (*mPreview);
|
MWBase::Environment::get().getWorld ()->setupExternalRendering (*mPreview);
|
||||||
mPreview->update (0);
|
mPreview->update (0);
|
||||||
|
|
||||||
|
const ESM::NPC proto = mPreview->getPrototype();
|
||||||
|
setRaceId(proto.mRace);
|
||||||
|
recountParts();
|
||||||
|
|
||||||
|
std::string index = proto.mHead.substr(proto.mHead.size() - 2, 2);
|
||||||
|
mFaceIndex = boost::lexical_cast<int>(index) - 1;
|
||||||
|
|
||||||
|
index = proto.mHair.substr(proto.mHair.size() - 2, 2);
|
||||||
|
mHairIndex = boost::lexical_cast<int>(index) - 1;
|
||||||
|
|
||||||
mPreviewImage->setImageTexture ("CharacterHeadPreview");
|
mPreviewImage->setImageTexture ("CharacterHeadPreview");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -143,6 +154,35 @@ int wrap(int index, int max)
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int countParts(const std::string &part, const std::string &race, bool male)
|
||||||
|
{
|
||||||
|
const MWWorld::Store<ESM::BodyPart> &store =
|
||||||
|
MWBase::Environment::get().getWorld()->getStore().get<ESM::BodyPart>();
|
||||||
|
|
||||||
|
std::string prefix =
|
||||||
|
"b_n_" + race + ((male) ? "_m_" : "_f_") + part;
|
||||||
|
|
||||||
|
std::string suffix;
|
||||||
|
suffix.reserve(prefix.size() + 3);
|
||||||
|
|
||||||
|
int count = -1;
|
||||||
|
do {
|
||||||
|
++count;
|
||||||
|
suffix = "_" + (boost::format("%02d") % (count + 1)).str();
|
||||||
|
}
|
||||||
|
while (store.search(prefix + suffix) != 0);
|
||||||
|
|
||||||
|
if (count == 0 && part == "hair") {
|
||||||
|
count = -1;
|
||||||
|
do {
|
||||||
|
++count;
|
||||||
|
suffix = (boost::format("%02d") % (count + 1)).str();
|
||||||
|
}
|
||||||
|
while (store.search(prefix + suffix) != 0);
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
void RaceDialog::close()
|
void RaceDialog::close()
|
||||||
{
|
{
|
||||||
delete mPreview;
|
delete mPreview;
|
||||||
|
@ -174,31 +214,41 @@ void RaceDialog::onHeadRotate(MyGUI::ScrollBar*, size_t _position)
|
||||||
void RaceDialog::onSelectPreviousGender(MyGUI::Widget*)
|
void RaceDialog::onSelectPreviousGender(MyGUI::Widget*)
|
||||||
{
|
{
|
||||||
mGenderIndex = wrap(mGenderIndex - 1, 2);
|
mGenderIndex = wrap(mGenderIndex - 1, 2);
|
||||||
|
|
||||||
|
recountParts();
|
||||||
|
updatePreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RaceDialog::onSelectNextGender(MyGUI::Widget*)
|
void RaceDialog::onSelectNextGender(MyGUI::Widget*)
|
||||||
{
|
{
|
||||||
mGenderIndex = wrap(mGenderIndex + 1, 2);
|
mGenderIndex = wrap(mGenderIndex + 1, 2);
|
||||||
|
|
||||||
|
recountParts();
|
||||||
|
updatePreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RaceDialog::onSelectPreviousFace(MyGUI::Widget*)
|
void RaceDialog::onSelectPreviousFace(MyGUI::Widget*)
|
||||||
{
|
{
|
||||||
mFaceIndex = wrap(mFaceIndex - 1, mFaceCount);
|
mFaceIndex = wrap(mFaceIndex - 1, mFaceCount);
|
||||||
|
updatePreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RaceDialog::onSelectNextFace(MyGUI::Widget*)
|
void RaceDialog::onSelectNextFace(MyGUI::Widget*)
|
||||||
{
|
{
|
||||||
mFaceIndex = wrap(mFaceIndex + 1, mFaceCount);
|
mFaceIndex = wrap(mFaceIndex + 1, mFaceCount);
|
||||||
|
updatePreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RaceDialog::onSelectPreviousHair(MyGUI::Widget*)
|
void RaceDialog::onSelectPreviousHair(MyGUI::Widget*)
|
||||||
{
|
{
|
||||||
mHairIndex = wrap(mHairIndex - 1, mHairCount);
|
mHairIndex = wrap(mHairIndex - 1, mHairCount);
|
||||||
|
updatePreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RaceDialog::onSelectNextHair(MyGUI::Widget*)
|
void RaceDialog::onSelectNextHair(MyGUI::Widget*)
|
||||||
{
|
{
|
||||||
mHairIndex = wrap(mHairIndex - 1, mHairCount);
|
mHairIndex = wrap(mHairIndex + 1, mHairCount);
|
||||||
|
updatePreview();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RaceDialog::onSelectRace(MyGUI::ListBox* _sender, size_t _index)
|
void RaceDialog::onSelectRace(MyGUI::ListBox* _sender, size_t _index)
|
||||||
|
@ -215,6 +265,26 @@ void RaceDialog::onSelectRace(MyGUI::ListBox* _sender, size_t _index)
|
||||||
|
|
||||||
mCurrentRaceId = *raceId;
|
mCurrentRaceId = *raceId;
|
||||||
|
|
||||||
|
recountParts();
|
||||||
|
|
||||||
|
updatePreview();
|
||||||
|
updateSkills();
|
||||||
|
updateSpellPowers();
|
||||||
|
}
|
||||||
|
|
||||||
|
void RaceDialog::recountParts()
|
||||||
|
{
|
||||||
|
mFaceIndex = 0;
|
||||||
|
mHairIndex = 0;
|
||||||
|
|
||||||
|
mFaceCount = countParts("head", mCurrentRaceId, mGenderIndex == 0);
|
||||||
|
mHairCount = countParts("hair", mCurrentRaceId, mGenderIndex == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// update widget content
|
||||||
|
|
||||||
|
void RaceDialog::updatePreview()
|
||||||
|
{
|
||||||
ESM::NPC record = mPreview->getPrototype();
|
ESM::NPC record = mPreview->getPrototype();
|
||||||
record.mRace = mCurrentRaceId;
|
record.mRace = mCurrentRaceId;
|
||||||
record.setIsMale(mGenderIndex == 0);
|
record.setIsMale(mGenderIndex == 0);
|
||||||
|
@ -222,27 +292,21 @@ void RaceDialog::onSelectRace(MyGUI::ListBox* _sender, size_t _index)
|
||||||
std::string prefix =
|
std::string prefix =
|
||||||
"b_n_" + mCurrentRaceId + ((record.isMale()) ? "_m_" : "_f_");
|
"b_n_" + mCurrentRaceId + ((record.isMale()) ? "_m_" : "_f_");
|
||||||
|
|
||||||
record.mHead = prefix + "head_01";
|
std::string headIndex = (boost::format("%02d") % (mFaceIndex + 1)).str();
|
||||||
record.mHair = prefix + "hair_01";
|
std::string hairIndex = (boost::format("%02d") % (mHairIndex + 1)).str();
|
||||||
|
|
||||||
|
record.mHead = prefix + "head_" + headIndex;
|
||||||
|
record.mHair = prefix + "hair_" + hairIndex;
|
||||||
|
|
||||||
const MWWorld::Store<ESM::BodyPart> &parts =
|
const MWWorld::Store<ESM::BodyPart> &parts =
|
||||||
MWBase::Environment::get().getWorld()->getStore().get<ESM::BodyPart>();
|
MWBase::Environment::get().getWorld()->getStore().get<ESM::BodyPart>();
|
||||||
|
|
||||||
if (parts.search(record.mHair) == 0) {
|
if (parts.search(record.mHair) == 0) {
|
||||||
record.mHair = prefix + "hair01";
|
record.mHair = prefix + "hair" + hairIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
mFaceIndex = 0;
|
|
||||||
mHairIndex = 0;
|
|
||||||
|
|
||||||
mPreview->setPrototype(record);
|
mPreview->setPrototype(record);
|
||||||
|
|
||||||
updateSkills();
|
|
||||||
updateSpellPowers();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// update widget content
|
|
||||||
|
|
||||||
void RaceDialog::updateRaces()
|
void RaceDialog::updateRaces()
|
||||||
{
|
{
|
||||||
mRaceList->removeAllItems();
|
mRaceList->removeAllItems();
|
||||||
|
|
|
@ -78,6 +78,8 @@ namespace MWGui
|
||||||
void updateRaces();
|
void updateRaces();
|
||||||
void updateSkills();
|
void updateSkills();
|
||||||
void updateSpellPowers();
|
void updateSpellPowers();
|
||||||
|
void updatePreview();
|
||||||
|
void recountParts();
|
||||||
|
|
||||||
MyGUI::ImageBox* mPreviewImage;
|
MyGUI::ImageBox* mPreviewImage;
|
||||||
MyGUI::ListBox* mRaceList;
|
MyGUI::ListBox* mRaceList;
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
#include <OgreSubMesh.h>
|
#include <OgreSubMesh.h>
|
||||||
#include <OgreSceneManager.h>
|
#include <OgreSceneManager.h>
|
||||||
|
|
||||||
|
|
||||||
namespace MWRender
|
namespace MWRender
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
|
@ -310,10 +310,13 @@ namespace MWRender
|
||||||
|
|
||||||
void Player::setAnimation(NpcAnimation *anim)
|
void Player::setAnimation(NpcAnimation *anim)
|
||||||
{
|
{
|
||||||
if (mAnimation) {
|
|
||||||
delete mAnimation;
|
delete mAnimation;
|
||||||
}
|
|
||||||
mAnimation = anim;
|
mAnimation = anim;
|
||||||
|
|
||||||
|
mPlayerNode->setVisible(
|
||||||
|
mVanity.enabled || mPreviewMode || !mFirstPersonView,
|
||||||
|
false
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Player::setHeight(float height)
|
void Player::setHeight(float height)
|
||||||
|
|
Loading…
Reference in a new issue