mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-10 00:43:59 +02:00
Merge pull request #4699 from SoundSSGood/backpack-arts-sorting
Backpack artifacts sorting
This commit is contained in:
commit
f6f6f98580
@ -192,6 +192,24 @@ void CCallback::scrollBackpackArtifacts(ObjectInstanceID hero, bool left)
|
|||||||
sendRequest(&mba);
|
sendRequest(&mba);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CCallback::sortBackpackArtifactsBySlot(const ObjectInstanceID hero)
|
||||||
|
{
|
||||||
|
ManageBackpackArtifacts mba(hero, ManageBackpackArtifacts::ManageCmd::SORT_BY_SLOT);
|
||||||
|
sendRequest(&mba);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CCallback::sortBackpackArtifactsByCost(const ObjectInstanceID hero)
|
||||||
|
{
|
||||||
|
ManageBackpackArtifacts mba(hero, ManageBackpackArtifacts::ManageCmd::SORT_BY_COST);
|
||||||
|
sendRequest(&mba);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CCallback::sortBackpackArtifactsByClass(const ObjectInstanceID hero)
|
||||||
|
{
|
||||||
|
ManageBackpackArtifacts mba(hero, ManageBackpackArtifacts::ManageCmd::SORT_BY_CLASS);
|
||||||
|
sendRequest(&mba);
|
||||||
|
}
|
||||||
|
|
||||||
void CCallback::manageHeroCostume(ObjectInstanceID hero, size_t costumeIndex, bool saveCostume)
|
void CCallback::manageHeroCostume(ObjectInstanceID hero, size_t costumeIndex, bool saveCostume)
|
||||||
{
|
{
|
||||||
ManageEquippedArtifacts mea(hero, costumeIndex, saveCostume);
|
ManageEquippedArtifacts mea(hero, costumeIndex, saveCostume);
|
||||||
|
@ -93,6 +93,9 @@ public:
|
|||||||
//virtual bool swapArtifacts(const CGHeroInstance * hero1, ui16 pos1, const CGHeroInstance * hero2, ui16 pos2)=0; //swaps artifacts between two given heroes
|
//virtual bool swapArtifacts(const CGHeroInstance * hero1, ui16 pos1, const CGHeroInstance * hero2, ui16 pos2)=0; //swaps artifacts between two given heroes
|
||||||
virtual bool swapArtifacts(const ArtifactLocation &l1, const ArtifactLocation &l2)=0;
|
virtual bool swapArtifacts(const ArtifactLocation &l1, const ArtifactLocation &l2)=0;
|
||||||
virtual void scrollBackpackArtifacts(ObjectInstanceID hero, bool left) = 0;
|
virtual void scrollBackpackArtifacts(ObjectInstanceID hero, bool left) = 0;
|
||||||
|
virtual void sortBackpackArtifactsBySlot(const ObjectInstanceID hero) = 0;
|
||||||
|
virtual void sortBackpackArtifactsByCost(const ObjectInstanceID hero) = 0;
|
||||||
|
virtual void sortBackpackArtifactsByClass(const ObjectInstanceID hero) = 0;
|
||||||
virtual void manageHeroCostume(ObjectInstanceID hero, size_t costumeIndex, bool saveCostume) = 0;
|
virtual void manageHeroCostume(ObjectInstanceID hero, size_t costumeIndex, bool saveCostume) = 0;
|
||||||
virtual void assembleArtifacts(const ObjectInstanceID & heroID, ArtifactPosition artifactSlot, bool assemble, ArtifactID assembleTo)=0;
|
virtual void assembleArtifacts(const ObjectInstanceID & heroID, ArtifactPosition artifactSlot, bool assemble, ArtifactID assembleTo)=0;
|
||||||
virtual void eraseArtifactByClient(const ArtifactLocation & al)=0;
|
virtual void eraseArtifactByClient(const ArtifactLocation & al)=0;
|
||||||
@ -180,6 +183,9 @@ public:
|
|||||||
void assembleArtifacts(const ObjectInstanceID & heroID, ArtifactPosition artifactSlot, bool assemble, ArtifactID assembleTo) override;
|
void assembleArtifacts(const ObjectInstanceID & heroID, ArtifactPosition artifactSlot, bool assemble, ArtifactID assembleTo) override;
|
||||||
void bulkMoveArtifacts(ObjectInstanceID srcHero, ObjectInstanceID dstHero, bool swap, bool equipped = true, bool backpack = true) override;
|
void bulkMoveArtifacts(ObjectInstanceID srcHero, ObjectInstanceID dstHero, bool swap, bool equipped = true, bool backpack = true) override;
|
||||||
void scrollBackpackArtifacts(ObjectInstanceID hero, bool left) override;
|
void scrollBackpackArtifacts(ObjectInstanceID hero, bool left) override;
|
||||||
|
void sortBackpackArtifactsBySlot(const ObjectInstanceID hero) override;
|
||||||
|
void sortBackpackArtifactsByCost(const ObjectInstanceID hero) override;
|
||||||
|
void sortBackpackArtifactsByClass(const ObjectInstanceID hero) override;
|
||||||
void manageHeroCostume(ObjectInstanceID hero, size_t costumeIdx, bool saveCostume) override;
|
void manageHeroCostume(ObjectInstanceID hero, size_t costumeIdx, bool saveCostume) override;
|
||||||
void eraseArtifactByClient(const ArtifactLocation & al) override;
|
void eraseArtifactByClient(const ArtifactLocation & al) override;
|
||||||
bool buildBuilding(const CGTownInstance *town, BuildingID buildingID) override;
|
bool buildBuilding(const CGTownInstance *town, BuildingID buildingID) override;
|
||||||
|
@ -350,6 +350,12 @@
|
|||||||
"vcmi.heroWindow.openCommander.help" : "Shows details about the commander of this hero.",
|
"vcmi.heroWindow.openCommander.help" : "Shows details about the commander of this hero.",
|
||||||
"vcmi.heroWindow.openBackpack.hover" : "Open artifact backpack window",
|
"vcmi.heroWindow.openBackpack.hover" : "Open artifact backpack window",
|
||||||
"vcmi.heroWindow.openBackpack.help" : "Opens window that allows easier artifact backpack management.",
|
"vcmi.heroWindow.openBackpack.help" : "Opens window that allows easier artifact backpack management.",
|
||||||
|
"vcmi.heroWindow.sortBackpackByCost.hover" : "Sort by cost",
|
||||||
|
"vcmi.heroWindow.sortBackpackByCost.help" : "Sort artifacts in backpack by cost.",
|
||||||
|
"vcmi.heroWindow.sortBackpackBySlot.hover" : "Sort by slot",
|
||||||
|
"vcmi.heroWindow.sortBackpackBySlot.help" : "Sort artifacts in backpack by equipped slot.",
|
||||||
|
"vcmi.heroWindow.sortBackpackByClass.hover" : "Sort by class",
|
||||||
|
"vcmi.heroWindow.sortBackpackByClass.help" : "Sort artifacts in backpack by artifact class. Treasure, Minor, Major, Relic",
|
||||||
|
|
||||||
"vcmi.tavernWindow.inviteHero" : "Invite hero",
|
"vcmi.tavernWindow.inviteHero" : "Invite hero",
|
||||||
|
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
#include "render/Canvas.h"
|
#include "render/Canvas.h"
|
||||||
#include "CPlayerInterface.h"
|
#include "CPlayerInterface.h"
|
||||||
|
|
||||||
|
#include "../../CCallback.h"
|
||||||
|
|
||||||
#include "../../lib/mapObjects/CGHeroInstance.h"
|
#include "../../lib/mapObjects/CGHeroInstance.h"
|
||||||
#include "../../lib/networkPacks/ArtifactLocation.h"
|
#include "../../lib/networkPacks/ArtifactLocation.h"
|
||||||
|
|
||||||
@ -41,17 +43,38 @@ CHeroBackpackWindow::CHeroBackpackWindow(const CGHeroInstance * hero, const std:
|
|||||||
};
|
};
|
||||||
addSet(arts);
|
addSet(arts);
|
||||||
arts->setHero(hero);
|
arts->setHero(hero);
|
||||||
quitButton = std::make_shared<CButton>(Point(), AnimationPath::builtin("IOKAY32.def"), CButton::tooltip(""),
|
|
||||||
[this]() { WindowBase::close(); }, EShortcut::GLOBAL_RETURN);
|
buttons.emplace_back(std::make_unique<CButton>(Point(), AnimationPath::builtin("ALTFILL.DEF"),
|
||||||
|
CButton::tooltipLocalized("vcmi.heroWindow.sortBackpackByCost"),
|
||||||
|
[hero]() { LOCPLINT->cb->sortBackpackArtifactsByCost(hero->id); }));
|
||||||
|
buttons.emplace_back(std::make_unique<CButton>(Point(), AnimationPath::builtin("ALTFILL.DEF"),
|
||||||
|
CButton::tooltipLocalized("vcmi.heroWindow.sortBackpackBySlot"),
|
||||||
|
[hero]() { LOCPLINT->cb->sortBackpackArtifactsBySlot(hero->id); }));
|
||||||
|
buttons.emplace_back(std::make_unique<CButton>(Point(), AnimationPath::builtin("ALTFILL.DEF"),
|
||||||
|
CButton::tooltipLocalized("vcmi.heroWindow.sortBackpackByClass"),
|
||||||
|
[hero]() { LOCPLINT->cb->sortBackpackArtifactsByClass(hero->id); }));
|
||||||
|
|
||||||
pos.w = stretchedBackground->pos.w = arts->pos.w + 2 * windowMargin;
|
pos.w = stretchedBackground->pos.w = arts->pos.w + 2 * windowMargin;
|
||||||
pos.h = stretchedBackground->pos.h = arts->pos.h + quitButton->pos.h + 3 * windowMargin;
|
pos.h = stretchedBackground->pos.h = arts->pos.h + buttons.back()->pos.h + 3 * windowMargin;
|
||||||
quitButton->moveTo(Point(pos.x + pos.w / 2 - quitButton->pos.w / 2, pos.y + arts->pos.h + 2 * windowMargin));
|
|
||||||
|
auto buttonPos = Point(pos.x + windowMargin, pos.y + arts->pos.h + 2 * windowMargin);
|
||||||
|
for(const auto & button : buttons)
|
||||||
|
{
|
||||||
|
button->moveTo(buttonPos);
|
||||||
|
buttonPos += Point(button->pos.w + 10, 0);
|
||||||
|
}
|
||||||
|
|
||||||
statusbar = CGStatusBar::create(0, pos.h, ImagePath::builtin("ADROLLVR.bmp"), pos.w);
|
statusbar = CGStatusBar::create(0, pos.h, ImagePath::builtin("ADROLLVR.bmp"), pos.w);
|
||||||
pos.h += statusbar->pos.h;
|
pos.h += statusbar->pos.h;
|
||||||
|
addUsedEvents(LCLICK);
|
||||||
center();
|
center();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CHeroBackpackWindow::notFocusedClick()
|
||||||
|
{
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
|
||||||
void CHeroBackpackWindow::showAll(Canvas & to)
|
void CHeroBackpackWindow::showAll(Canvas & to)
|
||||||
{
|
{
|
||||||
CIntObject::showAll(to);
|
CIntObject::showAll(to);
|
||||||
|
@ -17,10 +17,11 @@ class CHeroBackpackWindow : public CStatusbarWindow, public CWindowWithArtifacts
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CHeroBackpackWindow(const CGHeroInstance * hero, const std::vector<CArtifactsOfHeroPtr> & artsSets);
|
CHeroBackpackWindow(const CGHeroInstance * hero, const std::vector<CArtifactsOfHeroPtr> & artsSets);
|
||||||
|
void notFocusedClick() override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::shared_ptr<CArtifactsOfHeroBackpack> arts;
|
std::shared_ptr<CArtifactsOfHeroBackpack> arts;
|
||||||
std::shared_ptr<CButton> quitButton;
|
std::vector<std::unique_ptr<CButton>> buttons;
|
||||||
std::shared_ptr<CFilledTexture> stretchedBackground;
|
std::shared_ptr<CFilledTexture> stretchedBackground;
|
||||||
const int windowMargin = 5;
|
const int windowMargin = 5;
|
||||||
|
|
||||||
|
@ -2737,22 +2737,70 @@ bool CGameHandler::bulkMoveArtifacts(const PlayerColor & player, ObjectInstanceI
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CGameHandler::scrollBackpackArtifacts(const PlayerColor & player, const ObjectInstanceID heroID, bool left)
|
bool CGameHandler::manageBackpackArtifacts(const PlayerColor & player, const ObjectInstanceID heroID, const ManageBackpackArtifacts::ManageCmd & sortType)
|
||||||
{
|
{
|
||||||
const auto artSet = getArtSet(heroID);
|
const auto artSet = getArtSet(heroID);
|
||||||
COMPLAIN_RET_FALSE_IF(artSet == nullptr, "scrollBackpackArtifacts: wrong hero's ID");
|
COMPLAIN_RET_FALSE_IF(artSet == nullptr, "manageBackpackArtifacts: wrong hero's ID");
|
||||||
|
|
||||||
BulkMoveArtifacts bma(player, heroID, heroID, false);
|
BulkMoveArtifacts bma(player, heroID, heroID, false);
|
||||||
|
const auto makeSortBackpackRequest = [artSet, &bma](const std::function<int32_t(const ArtSlotInfo&)> & getSortId)
|
||||||
const auto backpackEnd = ArtifactPosition(ArtifactPosition::BACKPACK_START + artSet->artifactsInBackpack.size() - 1);
|
|
||||||
if(backpackEnd > ArtifactPosition::BACKPACK_START)
|
|
||||||
{
|
{
|
||||||
if(left)
|
std::map<int32_t, std::vector<BulkMoveArtifacts::LinkedSlots>> packsSorted;
|
||||||
bma.artsPack0.push_back(BulkMoveArtifacts::LinkedSlots(backpackEnd, ArtifactPosition::BACKPACK_START));
|
ArtifactPosition backpackSlot = ArtifactPosition::BACKPACK_START;
|
||||||
else
|
for(const auto & backpackSlotInfo : artSet->artifactsInBackpack)
|
||||||
bma.artsPack0.push_back(BulkMoveArtifacts::LinkedSlots(ArtifactPosition::BACKPACK_START, backpackEnd));
|
packsSorted.try_emplace(getSortId(backpackSlotInfo)).first->second.emplace_back(backpackSlot++, ArtifactPosition::PRE_FIRST);
|
||||||
sendAndApply(&bma);
|
|
||||||
|
for(auto & [sortId, pack] : packsSorted)
|
||||||
|
{
|
||||||
|
// Each pack of artifacts is also sorted by ArtifactID. Scrolls by SpellID
|
||||||
|
std::sort(pack.begin(), pack.end(), [artSet](const auto & slots0, const auto & slots1) -> bool
|
||||||
|
{
|
||||||
|
const auto art0 = artSet->getArt(slots0.srcPos);
|
||||||
|
const auto art1 = artSet->getArt(slots1.srcPos);
|
||||||
|
if(art0->isScroll() && art1->isScroll())
|
||||||
|
return art0->getScrollSpellID() > art1->getScrollSpellID();
|
||||||
|
return art0->getTypeId().num > art1->getTypeId().num;
|
||||||
|
});
|
||||||
|
bma.artsPack0.insert(bma.artsPack0.end(), pack.begin(), pack.end());
|
||||||
|
}
|
||||||
|
backpackSlot = ArtifactPosition::BACKPACK_START;
|
||||||
|
for(auto & slots : bma.artsPack0)
|
||||||
|
slots.dstPos = backpackSlot++;
|
||||||
|
};
|
||||||
|
|
||||||
|
if(sortType == ManageBackpackArtifacts::ManageCmd::SORT_BY_SLOT)
|
||||||
|
{
|
||||||
|
makeSortBackpackRequest([](const ArtSlotInfo & inf) -> int32_t
|
||||||
|
{
|
||||||
|
return inf.getArt()->artType->getPossibleSlots().at(ArtBearer::HERO).front().num;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
else if(sortType == ManageBackpackArtifacts::ManageCmd::SORT_BY_COST)
|
||||||
|
{
|
||||||
|
makeSortBackpackRequest([](const ArtSlotInfo & inf) -> int32_t
|
||||||
|
{
|
||||||
|
return inf.getArt()->artType->getPrice();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else if(sortType == ManageBackpackArtifacts::ManageCmd::SORT_BY_CLASS)
|
||||||
|
{
|
||||||
|
makeSortBackpackRequest([](const ArtSlotInfo & inf) -> int32_t
|
||||||
|
{
|
||||||
|
return inf.getArt()->artType->aClass;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const auto backpackEnd = ArtifactPosition(ArtifactPosition::BACKPACK_START + artSet->artifactsInBackpack.size() - 1);
|
||||||
|
if(backpackEnd > ArtifactPosition::BACKPACK_START)
|
||||||
|
{
|
||||||
|
if(sortType == ManageBackpackArtifacts::ManageCmd::SCROLL_LEFT)
|
||||||
|
bma.artsPack0.emplace_back(backpackEnd, ArtifactPosition::BACKPACK_START);
|
||||||
|
else
|
||||||
|
bma.artsPack0.emplace_back(ArtifactPosition::BACKPACK_START, backpackEnd);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sendAndApply(&bma);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include "../lib/LoadProgress.h"
|
#include "../lib/LoadProgress.h"
|
||||||
#include "../lib/ScriptHandler.h"
|
#include "../lib/ScriptHandler.h"
|
||||||
#include "../lib/gameState/GameStatistics.h"
|
#include "../lib/gameState/GameStatistics.h"
|
||||||
|
#include "../lib/networkPacks/PacksForServer.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
@ -142,7 +143,7 @@ public:
|
|||||||
void removeArtifact(const ObjectInstanceID & srcId, const std::vector<ArtifactPosition> & slotsPack);
|
void removeArtifact(const ObjectInstanceID & srcId, const std::vector<ArtifactPosition> & slotsPack);
|
||||||
bool moveArtifact(const PlayerColor & player, const ArtifactLocation & src, const ArtifactLocation & dst) override;
|
bool moveArtifact(const PlayerColor & player, const ArtifactLocation & src, const ArtifactLocation & dst) override;
|
||||||
bool bulkMoveArtifacts(const PlayerColor & player, ObjectInstanceID srcId, ObjectInstanceID dstId, bool swap, bool equipped, bool backpack);
|
bool bulkMoveArtifacts(const PlayerColor & player, ObjectInstanceID srcId, ObjectInstanceID dstId, bool swap, bool equipped, bool backpack);
|
||||||
bool scrollBackpackArtifacts(const PlayerColor & player, const ObjectInstanceID heroID, bool left);
|
bool manageBackpackArtifacts(const PlayerColor & player, const ObjectInstanceID heroID, const ManageBackpackArtifacts::ManageCmd & sortType);
|
||||||
bool saveArtifactsCostume(const PlayerColor & player, const ObjectInstanceID heroID, uint32_t costumeIdx);
|
bool saveArtifactsCostume(const PlayerColor & player, const ObjectInstanceID heroID, uint32_t costumeIdx);
|
||||||
bool switchArtifactsCostume(const PlayerColor & player, const ObjectInstanceID heroID, uint32_t costumeIdx);
|
bool switchArtifactsCostume(const PlayerColor & player, const ObjectInstanceID heroID, uint32_t costumeIdx);
|
||||||
bool eraseArtifactByClient(const ArtifactLocation & al);
|
bool eraseArtifactByClient(const ArtifactLocation & al);
|
||||||
|
@ -205,22 +205,7 @@ void ApplyGhNetPackVisitor::visitManageBackpackArtifacts(ManageBackpackArtifacts
|
|||||||
gh.throwIfPlayerNotActive(&pack);
|
gh.throwIfPlayerNotActive(&pack);
|
||||||
|
|
||||||
if(gh.getPlayerRelations(pack.player, gh.getOwner(pack.artHolder)) != PlayerRelations::ENEMIES)
|
if(gh.getPlayerRelations(pack.player, gh.getOwner(pack.artHolder)) != PlayerRelations::ENEMIES)
|
||||||
{
|
result = gh.manageBackpackArtifacts(pack.player, pack.artHolder, pack.cmd);
|
||||||
if(pack.cmd == ManageBackpackArtifacts::ManageCmd::SCROLL_LEFT)
|
|
||||||
result = gh.scrollBackpackArtifacts(pack.player, pack.artHolder, true);
|
|
||||||
else if(pack.cmd == ManageBackpackArtifacts::ManageCmd::SCROLL_RIGHT)
|
|
||||||
result = gh.scrollBackpackArtifacts(pack.player, pack.artHolder, false);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
gh.throwIfWrongOwner(&pack, pack.artHolder);
|
|
||||||
if(pack.cmd == ManageBackpackArtifacts::ManageCmd::SORT_BY_CLASS)
|
|
||||||
result = true;
|
|
||||||
else if(pack.cmd == ManageBackpackArtifacts::ManageCmd::SORT_BY_COST)
|
|
||||||
result = true;
|
|
||||||
else if(pack.cmd == ManageBackpackArtifacts::ManageCmd::SORT_BY_SLOT)
|
|
||||||
result = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ApplyGhNetPackVisitor::visitManageEquippedArtifacts(ManageEquippedArtifacts & pack)
|
void ApplyGhNetPackVisitor::visitManageEquippedArtifacts(ManageEquippedArtifacts & pack)
|
||||||
|
Loading…
Reference in New Issue
Block a user