git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@376 8ced0084-cf51-0410-be5f-012b33b47a6e

This commit is contained in:
Shawn Hoffman 2008-08-28 22:15:00 +00:00
parent 2e760d69fe
commit c32f116596
3 changed files with 90 additions and 167 deletions

View File

@ -204,7 +204,7 @@ void CFrame::CreateMenu()
// misc menu
wxMenu* miscMenu = new wxMenu;
miscMenu->Append(IDM_MEMCARD, _T("&Memory card manager"));
miscMenu->Append(IDM_MEMCARD, _T("&Memcard manager"));
miscMenu->AppendCheckItem(IDM_TOGGLE_TOOLBAR, _T("&Enable toolbar"));
miscMenu->Check(IDM_TOGGLE_TOOLBAR, true);
m_pMenuBar->Append(miscMenu, _T("&Misc"));

View File

@ -21,11 +21,10 @@
BEGIN_EVENT_TABLE(CMemcardManager, wxDialog)
EVT_CLOSE(CMemcardManager::OnClose)
EVT_RIGHT_DOWN(CMemcardManager::OnRightClick)
EVT_BUTTON(ID_COPYRIGHT,CMemcardManager::CopyClick)
EVT_BUTTON(ID_COPYLEFT,CMemcardManager::CopyClick)
EVT_BUTTON(ID_DELETERIGHT,CMemcardManager::DeleteClick)
EVT_BUTTON(ID_DELETELEFT,CMemcardManager::DeleteClick)
EVT_BUTTON(ID_COPYRIGHT,CMemcardManager::CopyDeleteClick)
EVT_BUTTON(ID_COPYLEFT,CMemcardManager::CopyDeleteClick)
EVT_BUTTON(ID_DELETERIGHT,CMemcardManager::CopyDeleteClick)
EVT_BUTTON(ID_DELETELEFT,CMemcardManager::CopyDeleteClick)
EVT_FILEPICKER_CHANGED(ID_MEMCARD1PATH,CMemcardManager::OnPathChange)
EVT_FILEPICKER_CHANGED(ID_MEMCARD2PATH,CMemcardManager::OnPathChange)
END_EVENT_TABLE()
@ -60,10 +59,10 @@ void CMemcardManager::CreateGUIControls()
m_Memcard2Path = new wxFilePickerCtrl(this, ID_MEMCARD2PATH, wxEmptyString, wxT("Choose a memory card:"),
wxT("Dolphin memcards (Mem*.raw)|Mem*.raw"), wxDefaultPosition, wxDefaultSize, wxFLP_USE_TEXTCTRL|wxFLP_FILE_MUST_EXIST|wxFLP_OPEN);
m_Memcard1List = new wxListCtrl(this, ID_MEMCARD1LIST, wxDefaultPosition, wxSize(500,400),
wxLC_REPORT | wxSUNKEN_BORDER | wxLC_ALIGN_LEFT | wxLC_SINGLE_SEL | wxLC_SORT_ASCENDING);
m_Memcard2List = new wxListCtrl(this, ID_MEMCARD2LIST, wxDefaultPosition, wxSize(500,400),
wxLC_REPORT | wxSUNKEN_BORDER | wxLC_ALIGN_LEFT | wxLC_SINGLE_SEL | wxLC_SORT_ASCENDING);
m_MemcardList[0] = new wxListCtrl(this, ID_MEMCARD1LIST, wxDefaultPosition, wxSize(350,400),
wxLC_REPORT | wxSUNKEN_BORDER | wxLC_ALIGN_LEFT | wxLC_SINGLE_SEL);
m_MemcardList[1] = new wxListCtrl(this, ID_MEMCARD2LIST, wxDefaultPosition, wxSize(350,400),
wxLC_REPORT | wxSUNKEN_BORDER | wxLC_ALIGN_LEFT | wxLC_SINGLE_SEL);
// mmmm sizer goodness
wxBoxSizer* sButtons;
@ -71,14 +70,15 @@ void CMemcardManager::CreateGUIControls()
sButtons->AddStretchSpacer(1);
sButtons->Add(m_CopyRight, 0, 0, 5);
sButtons->Add(m_CopyLeft, 0, 0, 5);
sButtons->AddStretchSpacer(2);
sButtons->Add(m_DeleteRight, 0, 0, 5);
sButtons->Add(m_DeleteLeft, 0, 0, 5);
sButtons->AddStretchSpacer(1);
sMemcard1->Add(m_Memcard1Path, 0, wxEXPAND|wxALL, 5);
sMemcard1->Add(m_Memcard1List, 1, wxEXPAND|wxALL, 5);
sMemcard1->Add(m_MemcardList[0], 1, wxEXPAND|wxALL, 5);
sMemcard2->Add(m_Memcard2Path, 0, wxEXPAND|wxALL, 5);
sMemcard2->Add(m_Memcard2List, 1, wxEXPAND|wxALL, 5);
sMemcard2->Add(m_MemcardList[1], 1, wxEXPAND|wxALL, 5);
//wxBoxSizer* sMain;
sMain = new wxBoxSizer(wxHORIZONTAL);
@ -101,154 +101,84 @@ void CMemcardManager::OnPathChange(wxFileDirPickerEvent& event)
switch(event.GetId())
{
case ID_MEMCARD1PATH:
LoadMemcard1(event.GetPath().mb_str());
ReloadMemcard(event.GetPath().mb_str(), 0);
break;
case ID_MEMCARD2PATH:
LoadMemcard2(event.GetPath().mb_str());
break;
default:
ReloadMemcard(event.GetPath().mb_str(), 1);
break;
}
}
void CMemcardManager::OnRightClick(wxMouseEvent& /*event*/)
void CMemcardManager::CopyDeleteClick(wxCommandEvent& event)
{
// Focus the clicked item.
//int flags;
//long item = HitTest(event.GetPosition(), flags);
//if (item != wxNOT_FOUND) {
// SetItemState(item, wxLIST_STATE_SELECTED | wxLIST_STATE_FOCUSED,
// wxLIST_STATE_SELECTED | wxLIST_STATE_FOCUSED);
//}
int index0 = m_MemcardList[0]->GetNextItem(-1, wxLIST_NEXT_ALL, wxLIST_STATE_SELECTED);;
int index1 = m_MemcardList[1]->GetNextItem(-1, wxLIST_NEXT_ALL, wxLIST_STATE_SELECTED);;
//int item = GetNextItem(-1, wxLIST_NEXT_ALL, wxLIST_STATE_SELECTED);
//if (item == -1)
//{
// //not found
//}
//else
//{
// //found
//}
switch(event.GetId())
{
case ID_COPYRIGHT:
if(index0 != -1 && m_MemcardList[1]->GetItemCount() > 0)
{
memoryCard[1]->CopyFrom(*memoryCard[0], index0);
memoryCard[1]->Save();
ReloadMemcard(m_Memcard2Path->GetPath().mb_str(), 1);
}
void CMemcardManager::CopyClick(wxCommandEvent& WXUNUSED (event))
break;
case ID_COPYLEFT:
if(index1 != -1 && m_MemcardList[0]->GetItemCount() > 0)
{
memoryCard[0]->CopyFrom(*memoryCard[1], index1);
memoryCard[0]->Save();
ReloadMemcard(m_Memcard1Path->GetPath().mb_str(), 0);
}
break;
case ID_DELETERIGHT:
if(index1 != -1)
{
memoryCard[1]->DeleteFile(index1);
memoryCard[1]->Save();
ReloadMemcard(m_Memcard2Path->GetPath().mb_str(), 1);
}
break;
case ID_DELETELEFT:
if(index0 != -1)
{
memoryCard[0]->DeleteFile(index0);
memoryCard[0]->Save();
ReloadMemcard(m_Memcard1Path->GetPath().mb_str(), 0);
}
break;
}
}
void CMemcardManager::DeleteClick(wxCommandEvent& WXUNUSED (event))
void CMemcardManager::ReloadMemcard(const char *fileName, int card)
{
// TODO: add error checking and banners/icons
memoryCard[card] = new GCMemcard(fileName);
}
m_MemcardList[card]->Hide();
m_MemcardList[card]->ClearAll();
m_MemcardList[card]->InsertColumn(COLUMN_TITLE, _T("Title"));
m_MemcardList[card]->InsertColumn(COLUMN_COMMENT, _T("Comment"));
// These next two functions really need to be merged - yet
// retain ability to only (re)load one card at a time.
void CMemcardManager::LoadMemcard1(const char *card1)
{
//wtf do these lines crash the app?
//if(memoryCard1) delete memoryCard1;
//if(memoryCard2) delete memoryCard2;
// WARNING: the memcards don't have much error checking, yet!
if(card1 && strlen(card1))
{
memoryCard1 = new GCMemcard(card1);
}
if(memoryCard1)
{
m_Memcard1List->Hide();
m_Memcard1List->ClearAll();
m_Memcard1List->InsertColumn(COLUMN_FILENAME, _T("filename"));
m_Memcard1List->InsertColumn(COLUMN_COMMENT1, _T("comment1"));
m_Memcard1List->InsertColumn(COLUMN_COMMENT2, _T("comment2"));
int nFiles = memoryCard1->GetNumFiles();
int nFiles = memoryCard[card]->GetNumFiles();
for(int i=0;i<nFiles;i++)
{
char fileName[32];
char comment1[32];
char comment2[32];
char title[32];
char comment[32];
if(!memoryCard1->GetFileName(i,fileName)) fileName[0]=0;
if(!memoryCard1->GetComment1(i,comment1)) comment1[0]=0;
if(!memoryCard1->GetComment2(i,comment2)) comment2[0]=0;
if(!memoryCard[card]->GetComment1(i,title)) title[0]=0;
if(!memoryCard[card]->GetComment2(i,comment)) comment[0]=0;
// Add to list control
int index = m_Memcard1List->InsertItem(i, wxString::FromAscii("row"));
m_Memcard1List->SetItem(index, 0, wxString::FromAscii(fileName));
m_Memcard1List->SetItem(index, 1, wxString::FromAscii(comment1));
m_Memcard1List->SetItem(index, 2, wxString::FromAscii(comment2));
int index = m_MemcardList[card]->InsertItem(i, wxString::FromAscii("row"));
m_MemcardList[card]->SetItem(index, 0, wxString::FromAscii(title));
m_MemcardList[card]->SetItem(index, 1, wxString::FromAscii(comment));
}
m_Memcard1List->Show();
}
else
{
m_Memcard2List->InsertColumn(COLUMN_FILENAME, _T("Error"));
m_MemcardList[card]->Show();
char tmp[128];
sprintf(tmp, "Unable to load %s", card1);
long item = m_Memcard1List->InsertItem(0, wxString::FromAscii(tmp));
m_Memcard1List->SetItemFont(item, *wxITALIC_FONT);
m_Memcard1List->SetColumnWidth(item, wxLIST_AUTOSIZE);
m_Memcard1List->SetItemState(0, wxLIST_STATE_SELECTED, wxLIST_STATE_SELECTED);
}
// automatic column width
for (int i = 0; i < m_Memcard1List->GetColumnCount(); i++)
for (int i = 0; i < m_MemcardList[card]->GetColumnCount(); i++)
{
m_Memcard1List->SetColumnWidth(i, wxLIST_AUTOSIZE);
}
}
void CMemcardManager::LoadMemcard2(const char *card2)
{
if(card2 && strlen(card2))
{
memoryCard2 = new GCMemcard(card2);
}
if(memoryCard2)
{
m_Memcard2List->Hide();
m_Memcard2List->ClearAll();
m_Memcard2List->InsertColumn(COLUMN_FILENAME, _T("filename"));
m_Memcard2List->InsertColumn(COLUMN_COMMENT1, _T("comment1"));
m_Memcard2List->InsertColumn(COLUMN_COMMENT2, _T("comment2"));
int nFiles = memoryCard2->GetNumFiles();
for(int i=0;i<nFiles;i++)
{
char fileName[32];
char comment1[32];
char comment2[32];
if(!memoryCard2->GetFileName(i,fileName)) fileName[0]=0;
if(!memoryCard2->GetComment1(i,comment1)) comment1[0]=0;
if(!memoryCard2->GetComment2(i,comment2)) comment2[0]=0;
int index = m_Memcard2List->InsertItem(i, wxString::FromAscii("row"));
m_Memcard2List->SetItem(index, 0, wxString::FromAscii(fileName));
m_Memcard2List->SetItem(index, 1, wxString::FromAscii(comment1));
m_Memcard2List->SetItem(index, 2, wxString::FromAscii(comment2));
}
m_Memcard2List->Show();
}
else
{
m_Memcard2List->InsertColumn(COLUMN_FILENAME, _T("Error"));
char tmp[128];
sprintf(tmp, "Unable to load %s", card2);
long item = m_Memcard2List->InsertItem(0, wxString::FromAscii(tmp));
m_Memcard2List->SetItemFont(item, *wxITALIC_FONT);
m_Memcard2List->SetColumnWidth(item, wxLIST_AUTOSIZE);
m_Memcard2List->SetItemState(0, wxLIST_STATE_SELECTED, wxLIST_STATE_SELECTED);
}
// automatic column width
for (int i = 0; i < m_Memcard2List->GetColumnCount(); i++)
{
m_Memcard2List->SetColumnWidth(i, wxLIST_AUTOSIZE);
m_MemcardList[card]->SetColumnWidth(i, wxLIST_AUTOSIZE);
}
}

View File

@ -34,7 +34,7 @@ class CMemcardManager
{
public:
CMemcardManager(wxWindow* parent, wxWindowID id = 1, const wxString& title = wxT("Memory Card Manager WARNING-In development, make backups first!"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = MEMCARD_MANAGER_STYLE);
CMemcardManager(wxWindow* parent, wxWindowID id = 1, const wxString& title = wxT("Memory Card Manager WARNING-Make backups before using, will probably mangle stuff!"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = MEMCARD_MANAGER_STYLE);
virtual ~CMemcardManager();
private:
@ -50,42 +50,35 @@ class CMemcardManager
wxStaticBoxSizer* sMemcard2;
wxFilePickerCtrl* m_Memcard1Path;
wxFilePickerCtrl* m_Memcard2Path;
wxListCtrl* m_Memcard1List;
wxListCtrl* m_Memcard2List;
wxListCtrl* m_MemcardList[2];
enum
{
ID_COPYRIGHT = 1000,
ID_COPYLEFT = 1001,
ID_DELETERIGHT = 1002,
ID_DELETELEFT = 1003,
ID_MEMCARD1PATH = 1004,
ID_MEMCARD2PATH = 1005,
ID_MEMCARD1LIST = 1006,
ID_MEMCARD2LIST = 1007,
ID_COPYLEFT,
ID_DELETERIGHT,
ID_DELETELEFT,
ID_MEMCARD1PATH,
ID_MEMCARD2PATH,
ID_MEMCARD1LIST,
ID_MEMCARD2LIST,
ID_DUMMY_VALUE_ //don't remove this value unless you have other enum values
};
enum
{
COLUMN_FILENAME = 0,
COLUMN_COMMENT1,
COLUMN_COMMENT2,
COLUMN_TITLE = 0,
COLUMN_COMMENT,
NUMBER_OF_COLUMN
};
GCMemcard *memoryCard1;
GCMemcard *memoryCard2;
void LoadMemcard1(const char *card1);
void LoadMemcard2(const char *card2);
void OnPathChange(wxFileDirPickerEvent& event);
GCMemcard *memoryCard[2];
void CreateGUIControls();
void OnRightClick(wxMouseEvent& event);
void OnClose(wxCloseEvent& event);
void CopyClick(wxCommandEvent& event);
void DeleteClick(wxCommandEvent& event);
void CopyDeleteClick(wxCommandEvent& event);
void ReloadMemcard(const char *fileName, int card);
void OnPathChange(wxFileDirPickerEvent& event);
};
#endif