Skip to content

Commit

Permalink
marvin 'toggle photomode'
Browse files Browse the repository at this point in the history
- hides framerate, clock, HP bar, mana bar, oxygen bar from UI
  • Loading branch information
Black_Fox committed Jun 23, 2023
1 parent 63bfe30 commit 8fbc5a3
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 20 deletions.
8 changes: 8 additions & 0 deletions game/camera.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -217,6 +217,14 @@ void Camera::toggleDebug() {
dbg = !dbg;
}

void Camera::togglePhotoMode() {
phm = !phm;
}

bool Camera::isPhotoMode() {
return phm;
}

void Camera::setSpin(const PointF &p) {
dst.spin = Vec3(p.x,p.y,0);
src.spin = dst.spin;
Expand Down
3 changes: 3 additions & 0 deletions game/camera.h
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ class Camera final {
void setLookBack(bool lb);

void toggleDebug();
void togglePhotoMode();
bool isPhotoMode();

void tick(uint64_t dt);
void debugDraw(DbgPainter& p);
Expand Down Expand Up @@ -142,6 +144,7 @@ class Camera final {
uint32_t vpHeight=0;

bool dbg = false;
bool phm = false;
bool tgEnable = true;
bool fpEnable = false;
bool lbEnable = false;
Expand Down
54 changes: 34 additions & 20 deletions game/mainwindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -198,16 +198,18 @@ void MainWindow::paintEvent(PaintEvent& event) {
paintFocus(p,focus,vp);

if(auto pl = Gothic::inst().player()){
float hp = float(pl->attribute(ATR_HITPOINTS))/float(pl->attribute(ATR_HITPOINTSMAX));
float mp = float(pl->attribute(ATR_MANA)) /float(pl->attribute(ATR_MANAMAX));
drawBar(p,barHp, 10, h()-10, hp, AlignLeft | AlignBottom);
drawBar(p,barMana,w()-10,h()-10, mp, AlignRight | AlignBottom);
if(pl->isDive()) {
uint32_t gl = pl->guild();
auto v = float(pl->world().script().guildVal().dive_time[gl]);
if(v>0) {
auto t = float(pl->diveTime())/1000.f;
drawBar(p,barMisc,w()/2,h()-10, (v-t)/(v), AlignHCenter | AlignBottom);
if (!camera.isPhotoMode()) {
float hp = float(pl->attribute(ATR_HITPOINTS))/float(pl->attribute(ATR_HITPOINTSMAX));
float mp = float(pl->attribute(ATR_MANA)) /float(pl->attribute(ATR_MANAMAX));
drawBar(p,barHp, 10, h()-10, hp, AlignLeft | AlignBottom);
drawBar(p,barMana,w()-10,h()-10, mp, AlignRight | AlignBottom);
if(pl->isDive()) {
uint32_t gl = pl->guild();
auto v = float(pl->world().script().guildVal().dive_time[gl]);
if(v>0) {
auto t = float(pl->diveTime())/1000.f;
drawBar(p,barMisc,w()/2,h()-10, (v-t)/(v), AlignHCenter | AlignBottom);
}
}
}
}
Expand Down Expand Up @@ -235,20 +237,32 @@ void MainWindow::paintEvent(PaintEvent& event) {
renderer.dbgDraw(p);

if(Gothic::inst().doFrate()) {
char fpsT[64]={};
std::snprintf(fpsT,sizeof(fpsT),"fps = %.2f",fps.get());
//string_frm fpsT("fps = ", fps.get(), " ", info);
bool printFrate = true;
if (world!=nullptr) {
auto& camera = *Gothic::inst().camera();
if (camera.isPhotoMode()) {
printFrate = false;
}
}
if (printFrate) {
char fpsT[64]={};
std::snprintf(fpsT,sizeof(fpsT),"fps = %.2f",fps.get());
//string_frm fpsT("fps = ", fps.get(), " ", info);

auto& fnt = Resources::font();
fnt.drawText(p,5,fnt.pixelSize()+5,fpsT);
auto& fnt = Resources::font();
fnt.drawText(p,5,fnt.pixelSize()+5,fpsT);
}
}

if(Gothic::inst().doClock() && world!=nullptr) {
auto hour = world->time().hour();
auto min = world->time().minute();
auto& fnt = Resources::font();
string_frm clockT(int(hour),":",int(min));
fnt.drawText(p,w()-fnt.textSize(clockT).w-5,fnt.pixelSize()+5,clockT);
auto& camera = *Gothic::inst().camera();
if (!camera.isPhotoMode()) {
auto hour = world->time().hour();
auto min = world->time().minute();
auto& fnt = Resources::font();
string_frm clockT(int(hour),":",int(min));
fnt.drawText(p,w()-fnt.textSize(clockT).w-5,fnt.pixelSize()+5,clockT);
}
}
}

Expand Down
6 changes: 6 additions & 0 deletions game/marvin.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ Marvin::Marvin() {
{"toggle camdebug", C_ToggleCamDebug},
{"toggle camera", C_ToggleCamera},
{"toggle inertiatarget", C_ToggleInertia},
{"toggle photomode", C_TogglePhotoMode},
{"insert %c", C_Insert},
};
}
Expand Down Expand Up @@ -328,6 +329,11 @@ bool Marvin::exec(std::string_view v) {
c->setInertiaTargetEnable(!c->isInertiaTargetEnabled());
return true;
}
case C_TogglePhotoMode: {
if(auto c = Gothic::inst().camera())
c->togglePhotoMode();
return true;
}
case C_Insert: {
World* world = Gothic::inst().world();
Npc* player = Gothic::inst().player();
Expand Down
1 change: 1 addition & 0 deletions game/marvin.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ class Marvin {
C_ToggleCamDebug,
C_ToggleCamera,
C_ToggleInertia,
C_TogglePhotoMode,

C_AiGoTo,
C_GoToPos,
Expand Down

0 comments on commit 8fbc5a3

Please sign in to comment.