mirror of
https://github.com/Poikilos/b3view.git
synced 2023-10-03 07:58:48 -07:00
Handle each GUI event type seperately as per Irrlicht documentation...
...Add a scope around cases to fix "error: jump to case label [-fpermissive]" and provide a separate scope for variables created in each case. Remove b3view.depend.
This commit is contained in:
parent
0f03078717
commit
50a9c1916d
@ -325,8 +325,12 @@ void UserInterface::incrementFrame(f32 frameCount, bool enableRound)
|
||||
}
|
||||
}
|
||||
|
||||
void UserInterface::handleMenuItemPressed(IGUIContextMenu* menu)
|
||||
bool UserInterface::handleMenuItemPressed(const SEvent::SGUIEvent* ge)
|
||||
{
|
||||
// ^ formerly ...(IGUIContextMenu* menu): called as ...(static_cast<IGUIContextMenu*>(ge->Caller)); protytyped as ...(irr::gui::IGUIContextMenu* menu)
|
||||
bool handled = true;
|
||||
IGUIContextMenu* menu = static_cast<IGUIContextMenu*>(ge->Caller);
|
||||
s32 callerID = ge->Caller->getID();
|
||||
s32 selected = menu->getSelectedItem();
|
||||
if (selected > -1) {
|
||||
s32 id = menu->getItemCommandId(static_cast<u32>(selected));
|
||||
@ -458,10 +462,22 @@ void UserInterface::handleMenuItemPressed(IGUIContextMenu* menu)
|
||||
);
|
||||
break;
|
||||
default:
|
||||
cerr << "[UserInterface::handleMenuItemPressed] Unknown caller id: " << id << endl;
|
||||
// if ((ge->Caller->getID() >= this->m_file_recent_first_idx)
|
||||
// && (ge->Caller->getID() <= m_file_recent_last_idx)) {
|
||||
if (std::find(this->recentIndices.begin(), this->recentIndices.end(), ge->Caller->getID()) != this->recentIndices.end()) {
|
||||
cerr << "Recent item id: " << callerID << endl;
|
||||
this->openRecent(callerID, ge->Caller->getText());
|
||||
}
|
||||
else {
|
||||
cerr << "Unknown caller id: " << callerID << " Text:" << ge->Caller->getText() << endl;
|
||||
handled = false;
|
||||
}
|
||||
|
||||
// cerr << "[UserInterface::handleMenuItemPressed] Unknown caller id: " << id << endl;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return handled;
|
||||
}
|
||||
|
||||
void UserInterface::updateSettingsDisplay()
|
||||
@ -898,29 +914,41 @@ bool UserInterface::OnEvent(const SEvent& event)
|
||||
handled = true; // set to false below if not handled
|
||||
const SEvent::SGUIEvent* ge = &(event.GUIEvent);
|
||||
s32 callerID = ge->Caller->getID();
|
||||
// TODO: switch (ge->EventType) {
|
||||
// // See http://irrlicht.sourceforge.net/docu/example009.html
|
||||
// case EGET_MENU_ITEM_SELECTED:
|
||||
// case EGET_SCROLL_BAR_CHANGED:
|
||||
// case EGET_COMBO_BOX_CHANGED:
|
||||
// case EGET_BUTTON_CLICKED:
|
||||
// switch(callerID) {
|
||||
// case UIE_PLAYBACKSTARTSTOPBUTTON:
|
||||
// default:
|
||||
// cerr << "Unknown button clicked: " << callerID << std::endl;
|
||||
// default:
|
||||
// cerr << "Unknown event.GUIEvent.EventType " << ge->EventType << std::endl;
|
||||
// break;
|
||||
switch (callerID) {
|
||||
case UIE_FILEMENU:
|
||||
case UIE_RECENTMENU:
|
||||
case UIE_PLAYBACKMENU:
|
||||
case UIE_VIEWMENU:
|
||||
// call handler for all menu related actions
|
||||
handleMenuItemPressed(static_cast<IGUIContextMenu*>(ge->Caller));
|
||||
switch (ge->EventType) {
|
||||
// See http://irrlicht.sourceforge.net/docu/example009.html
|
||||
case EGET_ELEMENT_FOCUSED:
|
||||
break;
|
||||
case EGET_ELEMENT_HOVERED:
|
||||
break;
|
||||
case EGET_ELEMENT_LEFT:
|
||||
break;
|
||||
case EGET_MENU_ITEM_SELECTED:
|
||||
handled = handleMenuItemPressed(ge);
|
||||
break;
|
||||
case EGET_SCROLL_BAR_CHANGED:
|
||||
break;
|
||||
case EGET_COMBO_BOX_CHANGED:
|
||||
break;
|
||||
case EGET_BUTTON_CLICKED:
|
||||
switch(callerID) {
|
||||
case UIE_PLAYBACKSTARTSTOPBUTTON:
|
||||
this->m_Engine->toggleAnimation();
|
||||
break;
|
||||
case UIE_PLAYBACKINCREASEBUTTON:
|
||||
this->m_Engine->incrementAnimationFPS(5);
|
||||
break;
|
||||
case UIE_PLAYBACKDECREASEBUTTON:
|
||||
this->m_Engine->incrementAnimationFPS(-5);
|
||||
break;
|
||||
default:
|
||||
cerr << "EGET_BUTTON_CLICKED wasn't expected from ID " << callerID << std::endl;
|
||||
handled = false;
|
||||
break;
|
||||
}
|
||||
case EGET_FILE_SELECTED:
|
||||
switch(callerID) {
|
||||
case UIE_LOADFILEDIALOG:
|
||||
if (ge->EventType == EGET_FILE_SELECTED) {
|
||||
{
|
||||
IGUIFileOpenDialog* fileOpenDialog = static_cast<IGUIFileOpenDialog*>(ge->Caller);
|
||||
wstring path = fileOpenDialog->getFileName();
|
||||
bool result = false;
|
||||
@ -946,9 +974,10 @@ bool UserInterface::OnEvent(const SEvent& event)
|
||||
L"Load Mesh", L"The model is inaccessible or not in a compatible format.");
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
case UIE_SAVEFILEDIALOG:
|
||||
if (ge->EventType == EGET_FILE_SELECTED) {
|
||||
{
|
||||
if (m_Engine->m_LoadedMesh != nullptr) {
|
||||
IGUIFileOpenDialog* fileOpenDialog = static_cast<IGUIFileOpenDialog*>(ge->Caller);
|
||||
// fileOpenDialog->getFileName()
|
||||
@ -960,99 +989,72 @@ bool UserInterface::OnEvent(const SEvent& event)
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case UIE_LOADTEXTUREDIALOG:
|
||||
if (ge->EventType == EGET_FILE_SELECTED) {
|
||||
{
|
||||
IGUIFileOpenDialog* fileOpenDialog = static_cast<IGUIFileOpenDialog*>(ge->Caller);
|
||||
m_Engine->loadTexture(fileOpenDialog->getFileName());
|
||||
}
|
||||
break;
|
||||
|
||||
case UIE_PLAYBACKSTARTSTOPBUTTON:
|
||||
if (ge->EventType == EGET_BUTTON_CLICKED) {
|
||||
this->m_Engine->toggleAnimation();
|
||||
}
|
||||
default:
|
||||
cerr << "EGET_FILE_SELECTED wasn't expected from ID: " << callerID << std::endl;
|
||||
handled = false;
|
||||
break;
|
||||
|
||||
case UIE_PLAYBACKINCREASEBUTTON:
|
||||
if (ge->EventType == EGET_BUTTON_CLICKED) {
|
||||
this->m_Engine->incrementAnimationFPS(5);
|
||||
}
|
||||
break;
|
||||
|
||||
case UIE_PLAYBACKDECREASEBUTTON:
|
||||
if (ge->EventType == EGET_BUTTON_CLICKED) {
|
||||
this->m_Engine->incrementAnimationFPS(-5);
|
||||
}
|
||||
break;
|
||||
|
||||
case EGET_EDITBOX_ENTER:
|
||||
switch (callerID) {
|
||||
case UIE_PLAYBACKSETFRAMEEDITBOX:
|
||||
if (ge->EventType == EGET_EDITBOX_ENTER) {
|
||||
if (this->m_Engine->m_LoadedMesh != nullptr) {
|
||||
this->m_Engine->m_LoadedMesh->setCurrentFrame(
|
||||
Utility::toF32(this->playbackSetFrameEditBox->getText())
|
||||
);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case UIE_PLAYBACKSTARTFRAMEEDITBOX:
|
||||
if (ge->EventType == EGET_EDITBOX_ENTER) {
|
||||
if (this->m_Engine->m_LoadedMesh != nullptr) {
|
||||
this->m_Engine->m_LoadedMesh->setFrameLoop(
|
||||
Utility::toF32(this->playbackStartFrameEditBox->getText()),
|
||||
Utility::toF32(this->playbackEndFrameEditBox->getText())
|
||||
);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case UIE_PLAYBACKENDFRAMEEDITBOX:
|
||||
if (ge->EventType == EGET_EDITBOX_ENTER) {
|
||||
if (this->m_Engine->m_LoadedMesh != nullptr) {
|
||||
this->m_Engine->m_LoadedMesh->setFrameLoop(
|
||||
Utility::toF32(this->playbackStartFrameEditBox->getText()),
|
||||
Utility::toF32(this->playbackEndFrameEditBox->getText())
|
||||
);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case UIE_TEXTUREPATHEDITBOX:
|
||||
if (ge->EventType == EGET_EDITBOX_ENTER) {
|
||||
if (this->m_Engine->m_LoadedMesh != nullptr) {
|
||||
this->m_Engine->loadTexture(texturePathEditBox->getText());
|
||||
}
|
||||
}
|
||||
break;
|
||||
case UIE_FPSEDITBOX:
|
||||
if (ge->EventType == EGET_EDITBOX_ENTER) {
|
||||
if (this->m_Engine->m_LoadedMesh != nullptr) {
|
||||
this->m_Engine->m_LoadedMesh->setAnimationSpeed(
|
||||
Utility::toF32(this->playbackFPSEditBox->getText())
|
||||
);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case UIE_AXISSIZEEDITBOX:
|
||||
if (ge->EventType == EGET_EDITBOX_ENTER) {
|
||||
this->m_Engine->m_AxisLength = Utility::toF32(
|
||||
this->axisSizeEditBox->getText()
|
||||
);
|
||||
}
|
||||
break;
|
||||
case -1:
|
||||
break;
|
||||
default:
|
||||
// if ((ge->Caller->getID() >= this->m_file_recent_first_idx)
|
||||
// && (ge->Caller->getID() <= m_file_recent_last_idx)) {
|
||||
if (std::find(this->recentIndices.begin(), this->recentIndices.end(), ge->Caller->getID()) != this->recentIndices.end()) {
|
||||
cerr << "Recent item id: " << callerID << endl;
|
||||
this->openRecent(callerID, ge->Caller->getText());
|
||||
}
|
||||
else {
|
||||
cerr << "Unknown caller id: " << callerID << " Text:" << ge->Caller->getText() << endl;
|
||||
|
||||
cerr << "EGET_EDITBOX_ENTER isn't processed for ID: " << callerID << std::endl;
|
||||
handled = false;
|
||||
break;
|
||||
}
|
||||
default:
|
||||
// EET_MOUSE_INPUT_EVENT EET_KEY_INPUT_EVENT EET_JOYSTICK_INPUT_EVENT
|
||||
cerr << "[UserInterface] (verbose message) event.GUIEvent.EventType " << ge->EventType << " (See EGET_*) is not handled (event.EventType is EET_GUI_EVENT)." << std::endl;
|
||||
handled = false;
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
} else if (event.EventType == EET_KEY_INPUT_EVENT) {
|
||||
// debug() << "EET_KEY_INPUT_EVENT..." << endl;
|
||||
handled = true; // set to false below if not handled
|
||||
@ -1162,6 +1164,8 @@ bool UserInterface::OnEvent(const SEvent& event)
|
||||
default:
|
||||
handled = false;
|
||||
}
|
||||
} else {
|
||||
cerr << "[UserInterface] (verbose message) event.EventType " << event.EventType << " is ignored." << std::endl;
|
||||
}
|
||||
return handled;
|
||||
}
|
||||
|
@ -84,7 +84,7 @@ private:
|
||||
void displaySaveFileDialog();
|
||||
void displayLoadTextureDialog();
|
||||
void incrementFrame(irr::f32 frameCount, bool enableRound);
|
||||
void handleMenuItemPressed(irr::gui::IGUIContextMenu* menu);
|
||||
bool handleMenuItemPressed(const irr::SEvent::SGUIEvent* ge);
|
||||
void updateSettingsDisplay();
|
||||
|
||||
irr::gui::IGUIWindow* playbackWindow;
|
||||
|
239
b3view.depend
239
b3view.depend
@ -1,239 +0,0 @@
|
||||
# depslib dependency file v1.0
|
||||
1554970747 source:/opt/b3view/Debug.cpp
|
||||
"Debug.h"
|
||||
|
||||
1616415754 /opt/b3view/Debug.h
|
||||
<iostream>
|
||||
|
||||
1616415912 source:/opt/b3view/Engine.cpp
|
||||
<string>
|
||||
<filesystem>
|
||||
"Engine.h"
|
||||
"UserInterface.h"
|
||||
"Utility.h"
|
||||
"View.h"
|
||||
<cerrno>
|
||||
<unistd.h>
|
||||
|
||||
1613679774 /opt/b3view/Engine.h
|
||||
<iostream>
|
||||
<sstream>
|
||||
<string>
|
||||
<vector>
|
||||
"EventHandler.h"
|
||||
"extlib/CGUITTFont.h"
|
||||
<irrlicht/irrlicht.h>
|
||||
"settings.h"
|
||||
|
||||
1554970974 /opt/b3view/EventHandler.h
|
||||
<iostream>
|
||||
<map>
|
||||
<utility>
|
||||
"Debug.h"
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1616368477 /opt/b3view/extlib/CGUITTFont.h
|
||||
<ft2build.h>
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1613661547 /opt/b3view/settings.h
|
||||
<string>
|
||||
<map>
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1613683794 /opt/b3view/UserInterface.h
|
||||
"extlib/CGUITTFont.h"
|
||||
<irrlicht/irrlicht.h>
|
||||
<string>
|
||||
<vector>
|
||||
|
||||
1613676318 /opt/b3view/Utility.h
|
||||
<irrlicht/irrlicht.h>
|
||||
<ctime>
|
||||
<string>
|
||||
<vector>
|
||||
|
||||
1555700256 /opt/b3view/View.h
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1613660813 source:/opt/b3view/EventHandler.cpp
|
||||
"EventHandler.h"
|
||||
"Utility.h"
|
||||
<string.h>
|
||||
<sys/stat.h>
|
||||
<sys/types.h>
|
||||
|
||||
1554967184 source:/opt/b3view/extlib/CGUITTFont.cpp
|
||||
<assert.h>
|
||||
<iostream>
|
||||
<irrlicht/irrlicht.h>
|
||||
"CGUITTFont.h"
|
||||
|
||||
1562175368 source:/opt/b3view/main.cpp
|
||||
<malloc.h>
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
"Engine.h"
|
||||
<Windows.h>
|
||||
|
||||
1616415840 source:/opt/b3view/settings.cpp
|
||||
"Utility.h"
|
||||
"settings.h"
|
||||
<fstream>
|
||||
<iostream>
|
||||
<vector>
|
||||
<algorithm>
|
||||
<assert.h>
|
||||
|
||||
1616415979 source:/opt/b3view/UserInterface.cpp
|
||||
"Debug.h"
|
||||
"Engine.h"
|
||||
"Utility.h"
|
||||
"UserInterface.h"
|
||||
<algorithm>
|
||||
<iostream>
|
||||
<string>
|
||||
<experimental/filesystem>
|
||||
|
||||
1613676405 source:/opt/b3view/Utility.cpp
|
||||
"Debug.h"
|
||||
"Utility.h"
|
||||
<algorithm>
|
||||
<clocale>
|
||||
<cmath>
|
||||
<cwctype>
|
||||
<iostream>
|
||||
<filesystem>
|
||||
<locale>
|
||||
<sstream>
|
||||
<string>
|
||||
<vector>
|
||||
<assert.h>
|
||||
<sys/stat.h>
|
||||
<experimental/filesystem>
|
||||
|
||||
1613676471 source:/opt/b3view/View.cpp
|
||||
"Engine.h"
|
||||
"Utility.h"
|
||||
"View.h"
|
||||
<iostream>
|
||||
|
||||
1554970747 source:/home/owner/git/b3view/Debug.cpp
|
||||
"Debug.h"
|
||||
|
||||
1616415754 /home/owner/git/b3view/Debug.h
|
||||
<iostream>
|
||||
|
||||
1613660813 source:/home/owner/git/b3view/EventHandler.cpp
|
||||
"EventHandler.h"
|
||||
"Utility.h"
|
||||
<string.h>
|
||||
<sys/stat.h>
|
||||
<sys/types.h>
|
||||
|
||||
1554970974 /home/owner/git/b3view/EventHandler.h
|
||||
<iostream>
|
||||
<map>
|
||||
<utility>
|
||||
"Debug.h"
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1613676318 /home/owner/git/b3view/Utility.h
|
||||
<irrlicht/irrlicht.h>
|
||||
<ctime>
|
||||
<string>
|
||||
<vector>
|
||||
|
||||
1616417794 source:/home/owner/git/b3view/extlib/CGUITTFont.cpp
|
||||
<assert.h>
|
||||
<iostream>
|
||||
<irrlicht/irrlicht.h>
|
||||
"CGUITTFont.h"
|
||||
|
||||
1616368477 /home/owner/git/b3view/extlib/CGUITTFont.h
|
||||
<ft2build.h>
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1562175368 source:/home/owner/git/b3view/main.cpp
|
||||
<malloc.h>
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
"Engine.h"
|
||||
<Windows.h>
|
||||
|
||||
1613679774 /home/owner/git/b3view/Engine.h
|
||||
<iostream>
|
||||
<sstream>
|
||||
<string>
|
||||
<vector>
|
||||
"EventHandler.h"
|
||||
"extlib/CGUITTFont.h"
|
||||
<irrlicht/irrlicht.h>
|
||||
"settings.h"
|
||||
|
||||
1613661547 /home/owner/git/b3view/settings.h
|
||||
<string>
|
||||
<map>
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1616420536 source:/home/owner/git/b3view/settings.cpp
|
||||
"Utility.h"
|
||||
"settings.h"
|
||||
<fstream>
|
||||
<iostream>
|
||||
<vector>
|
||||
<algorithm>
|
||||
<assert.h>
|
||||
|
||||
1613676405 source:/home/owner/git/b3view/Utility.cpp
|
||||
"Debug.h"
|
||||
"Utility.h"
|
||||
<algorithm>
|
||||
<clocale>
|
||||
<cmath>
|
||||
<cwctype>
|
||||
<iostream>
|
||||
<filesystem>
|
||||
<locale>
|
||||
<sstream>
|
||||
<string>
|
||||
<vector>
|
||||
<assert.h>
|
||||
<sys/stat.h>
|
||||
<experimental/filesystem>
|
||||
|
||||
1613676471 source:/home/owner/git/b3view/View.cpp
|
||||
"Engine.h"
|
||||
"Utility.h"
|
||||
"View.h"
|
||||
<iostream>
|
||||
|
||||
1555700256 /home/owner/git/b3view/View.h
|
||||
<irrlicht/irrlicht.h>
|
||||
|
||||
1616420911 source:/home/owner/git/b3view/Engine.cpp
|
||||
<string>
|
||||
<filesystem>
|
||||
"Engine.h"
|
||||
"UserInterface.h"
|
||||
"Utility.h"
|
||||
"View.h"
|
||||
<cerrno>
|
||||
<unistd.h>
|
||||
|
||||
1613683794 /home/owner/git/b3view/UserInterface.h
|
||||
"extlib/CGUITTFont.h"
|
||||
<irrlicht/irrlicht.h>
|
||||
<string>
|
||||
<vector>
|
||||
|
||||
1616419830 source:/home/owner/git/b3view/UserInterface.cpp
|
||||
"Debug.h"
|
||||
"Engine.h"
|
||||
"Utility.h"
|
||||
"UserInterface.h"
|
||||
<algorithm>
|
||||
<iostream>
|
||||
<string>
|
||||
<experimental/filesystem>
|
||||
|
Loading…
x
Reference in New Issue
Block a user