X-Git-Url: http://Server1/repobrowser/?a=blobdiff_plain;f=source%2Fcontacteditor%2FfrmContactEditor-Logo.cpp;h=e4f7c966f8a2532cf9ded2fdc1512b2f6a94c29a;hb=bac054ea5eda94fe663d8b1a7c680ae80de8075c;hp=808e2d58769b07b0b6228e4a66cf29cfd54751b9;hpb=79aa666accc0e96fbc82ae22bc621704b8912618;p=xestiaab%2F.git diff --git a/source/contacteditor/frmContactEditor-Logo.cpp b/source/contacteditor/frmContactEditor-Logo.cpp index 808e2d5..e4f7c96 100644 --- a/source/contacteditor/frmContactEditor-Logo.cpp +++ b/source/contacteditor/frmContactEditor-Logo.cpp @@ -23,150 +23,163 @@ void frmContactEditor::LoadLogo( wxListEvent& event ) { - long longSelected = -1; - int intSelectedData = 0; - - if (!GetSelectedItem(lboLogos, - &longSelected, - &intSelectedData)){ - return; - } + // Load the logo. + + long longSelected = -1; + int intSelectedData = 0; - std::string base64dec; + if (lboLogos->GetItemCount() == 0 || !GetSelectedItem(lboLogos, + &longSelected, + &intSelectedData)){ + return; + } - std::map::iterator initier; - std::map::iterator pictypeiter; + std::string base64dec; - initier = ContactEditorData.LogosList.find(intSelectedData); - pictypeiter = ContactEditorData.LogosListPictureType.find(intSelectedData); + std::map::iterator initier; + std::map::iterator pictypeiter; - base64dec = base64_decode(initier->second); + initier = ContactEditorData.LogosList.find(intSelectedData); + pictypeiter = ContactEditorData.LogosListPictureType.find(intSelectedData); - wxMemoryInputStream istream(base64dec.c_str(), (size_t)base64dec.size()); - wxImage photo; - //wxMemoryInputStream istream(base64dec, (size_t)base64dec.size()); + base64dec = base64_decode(initier->second); - if (pictypeiter->second == wxT("image/jpeg")){ + wxMemoryInputStream istream(base64dec.c_str(), (size_t)base64dec.size()); + wxImage photo; + + if (pictypeiter->second == wxT("image/jpeg")){ - if (!photo.LoadFile(istream, wxBITMAP_TYPE_JPEG)){ + if (!photo.LoadFile(istream, wxBITMAP_TYPE_JPEG)){ - return; + return; - } + } - } else if (pictypeiter->second == wxT("image/png")){ + } else if (pictypeiter->second == wxT("image/png")){ - if (!photo.LoadFile(istream, wxBITMAP_TYPE_PNG)){ + if (!photo.LoadFile(istream, wxBITMAP_TYPE_PNG)){ - return; + return; - } + } - } else if (pictypeiter->second == wxT("image/gif")){ + } else if (pictypeiter->second == wxT("image/gif")){ - if (!photo.LoadFile(istream, wxBITMAP_TYPE_GIF)){ + if (!photo.LoadFile(istream, wxBITMAP_TYPE_GIF)){ - return; + return; - } + } - } else { + } else { - return; + return; - } + } - LogoImage = (wxBitmap)photo; - imgLogo->SetBitmap(LogoImage); + LogoImage = (wxBitmap)photo; + imgLogo->SetBitmap(LogoImage); } void frmContactEditor::AddLogo( wxCommandEvent& event ) { - int intResult = 0; - - frmContactEditorPicture *frameCELogo = new frmContactEditorPicture ( this ); - frameCELogo->SetEditorMode(FALSE); - intResult = GetLastInt(&ContactEditorData.LogosList); - frameCELogo->SetupPointers(&ContactEditorData.LogosList, - &ContactEditorData.LogosListAltID, - &ContactEditorData.LogosListPID, - &ContactEditorData.LogosListType, - &ContactEditorData.LogosListPicEncType, - &ContactEditorData.LogosListPictureType, - &ContactEditorData.LogosListTokens, - &ContactEditorData.LogosListMediatype, - &ContactEditorData.LogosListPref, - lboLogos, - (intValueSeek), - FALSE); - frameCELogo->ShowModal(); - delete frameCELogo; - frameCELogo = NULL; + + // Bring up the window to add a logo. + + frmContactEditorPicture *frameCELogo = new frmContactEditorPicture ( this ); + frameCELogo->SetEditorMode(FALSE); + frameCELogo->SetupPointers(&ContactEditorData.LogosList, + &ContactEditorData.LogosListAltID, + &ContactEditorData.LogosListPID, + &ContactEditorData.LogosListType, + &ContactEditorData.LogosListPicEncType, + &ContactEditorData.LogosListPictureType, + &ContactEditorData.LogosListTokens, + &ContactEditorData.LogosListMediatype, + &ContactEditorData.LogosListPref, + lboLogos, + (intValueSeek), + FALSE); + frameCELogo->ShowModal(); + delete frameCELogo; + frameCELogo = NULL; + intValueSeek++; + } void frmContactEditor::ModifyLogo( wxCommandEvent& event ) { - long longSelected = -1; - int intSelectedData = 0; + + // Bring up the window to modify a logo. + + long longSelected = -1; + int intSelectedData = 0; - if (!GetSelectedItem(lboLogos, - &longSelected, - &intSelectedData)){ - return; - } - - frmContactEditorPicture *frameCELogo = new frmContactEditorPicture ( this ); - frameCELogo->SetupPointers(&ContactEditorData.LogosList, - &ContactEditorData.LogosListAltID, - &ContactEditorData.LogosListPID, - &ContactEditorData.LogosListType, - &ContactEditorData.LogosListPicEncType, - &ContactEditorData.LogosListPictureType, - &ContactEditorData.LogosListTokens, - &ContactEditorData.LogosListMediatype, - &ContactEditorData.LogosListPref, - lboLogos, - intSelectedData, - FALSE); - frameCELogo->SetEditorMode(TRUE); - frameCELogo->ShowModal(); - delete frameCELogo; - frameCELogo = NULL; + if (lboLogos->GetItemCount() == 0 || !GetSelectedItem(lboLogos, + &longSelected, + &intSelectedData)){ + return; + } + + frmContactEditorPicture *frameCELogo = new frmContactEditorPicture ( this ); + frameCELogo->SetupPointers(&ContactEditorData.LogosList, + &ContactEditorData.LogosListAltID, + &ContactEditorData.LogosListPID, + &ContactEditorData.LogosListType, + &ContactEditorData.LogosListPicEncType, + &ContactEditorData.LogosListPictureType, + &ContactEditorData.LogosListTokens, + &ContactEditorData.LogosListMediatype, + &ContactEditorData.LogosListPref, + lboLogos, + intSelectedData, + FALSE); + frameCELogo->SetEditorMode(TRUE); + frameCELogo->ShowModal(); + delete frameCELogo; + frameCELogo = NULL; + } void frmContactEditor::DeleteLogo( wxCommandEvent& event ) { - long longSelected = -1; - int intSelectedData = 0; + + // Bring up a window to delete a logo. + + long longSelected = -1; + int intSelectedData = 0; - if (!GetSelectedItem(lboLogos, - &longSelected, - &intSelectedData)){ - return; - } + if (lboLogos->GetItemCount() == 0 || !GetSelectedItem(lboLogos, + &longSelected, + &intSelectedData)){ + return; + } - lboLogos->DeleteItem(longSelected); + lboLogos->DeleteItem(longSelected); - DeleteMapData(intSelectedData, - &ContactEditorData.LogosList, &ContactEditorData.LogosListAltID, &ContactEditorData.LogosListPID, &ContactEditorData.LogosListType, - &ContactEditorData.LogosListPicEncType, &ContactEditorData.LogosListPictureType, &ContactEditorData.LogosListTokens, - &ContactEditorData.LogosListMediatype, &ContactEditorData.LogosListPref); + DeleteMapData(intSelectedData, + &ContactEditorData.LogosList, &ContactEditorData.LogosListAltID, &ContactEditorData.LogosListPID, &ContactEditorData.LogosListType, + &ContactEditorData.LogosListPicEncType, &ContactEditorData.LogosListPictureType, &ContactEditorData.LogosListTokens, + &ContactEditorData.LogosListMediatype, &ContactEditorData.LogosListPref); - wxMemoryInputStream istream(misc_emptyimage_png, sizeof(misc_emptyimage_png)); - wxImage misc_emptyimage_png(istream, wxBITMAP_TYPE_PNG); - LogoImage = (wxBitmap)misc_emptyimage_png; + wxMemoryInputStream istream(misc_emptyimage_png, sizeof(misc_emptyimage_png)); + wxImage misc_emptyimage_png(istream, wxBITMAP_TYPE_PNG); + LogoImage = (wxBitmap)misc_emptyimage_png; - imgLogo->SetBitmap(LogoImage); + imgLogo->SetBitmap(LogoImage); + } void frmContactEditor::SaveLogo( wxCommandEvent &event ) { + // Save the logo to a file. + long longSelected = -1; int intSelectedData = 0; - if (!GetSelectedItem(lboLogos, + if (lboLogos->GetItemCount() == 0 || !GetSelectedItem(lboLogos, &longSelected, &intSelectedData)){