📄 winutil.h
字号:
/*
* Copyright (C) 2001-2005 Jacek Sieka, arnetheduck on gmail point com
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef __WINUTIL_H
#define __WINUTIL_H
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include "../client/Util.h"
#include "../client/SettingsManager.h"
#include "../client/User.h"
#include "../client/MerkleTree.h"
// Some utilities for handling HLS colors, taken from Jean-Michel LE FOL's codeproject
// article on WTL OfficeXP Menus
typedef DWORD HLSCOLOR;
#define HLS(h,l,s) ((HLSCOLOR)(((BYTE)(h)|((WORD)((BYTE)(l))<<8))|(((DWORD)(BYTE)(s))<<16)))
#define HLS_H(hls) ((BYTE)(hls))
#define HLS_L(hls) ((BYTE)(((WORD)(hls)) >> 8))
#define HLS_S(hls) ((BYTE)((hls)>>16))
HLSCOLOR RGB2HLS (COLORREF rgb);
COLORREF HLS2RGB (HLSCOLOR hls);
COLORREF HLS_TRANSFORM (COLORREF rgb, int percent_L, int percent_S);
class UserInfoBase {
public:
UserInfoBase(const User::Ptr& u) : user(u) { };
void getList();
void browseList();
void matchQueue();
void pm();
void grant();
void addFav();
void removeAll();
User::Ptr& getUser() { return user; }
User::Ptr user;
};
template<class T>
class UserInfoBaseHandler {
public:
BEGIN_MSG_MAP(UserInfoBaseHandler)
COMMAND_ID_HANDLER(IDC_GETLIST, onGetList)
COMMAND_ID_HANDLER(IDC_BROWSELIST, onBrowseList)
COMMAND_ID_HANDLER(IDC_MATCH_QUEUE, onMatchQueue)
COMMAND_ID_HANDLER(IDC_PRIVATEMESSAGE, onPrivateMessage)
COMMAND_ID_HANDLER(IDC_ADD_TO_FAVORITES, onAddToFavorites)
COMMAND_ID_HANDLER(IDC_GRANTSLOT, onGrantSlot)
COMMAND_ID_HANDLER(IDC_REMOVEALL, onRemoveAll)
END_MSG_MAP()
LRESULT onMatchQueue(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::matchQueue);
return 0;
}
LRESULT onGetList(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::getList);
return 0;
}
LRESULT onBrowseList(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::browseList);
return 0;
}
LRESULT onAddToFavorites(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::addFav);
return 0;
}
LRESULT onPrivateMessage(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::pm);
return 0;
}
LRESULT onGrantSlot(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::grant);
return 0;
}
LRESULT onRemoveAll(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
((T*)this)->getUserList().forEachSelected(&UserInfoBase::removeAll);
return 0;
}
struct NmdcOnly {
NmdcOnly() : nmdcOnly(true) { }
void operator()(UserInfoBase* ui) { if(!ui->getUser()->getCID().isZero()) nmdcOnly = false; }
bool nmdcOnly;
};
void checkAdcItems(CMenu& menu) {
MENUITEMINFO mii = { 0 };
mii.cbSize = sizeof(mii);
mii.fMask = MIIM_STATE;
if(((T*)this)->getUserList().forEachSelectedT(NmdcOnly()).nmdcOnly) {
menu.EnableMenuItem(IDC_BROWSELIST, MFS_DISABLED);
} else {
menu.EnableMenuItem(IDC_BROWSELIST, MFS_ENABLED);
}
}
void appendUserItems(CMenu& menu) {
menu.AppendMenu(MF_STRING, IDC_GETLIST, CTSTRING(GET_FILE_LIST));
menu.AppendMenu(MF_STRING, IDC_BROWSELIST, CTSTRING(BROWSE_FILE_LIST));
menu.AppendMenu(MF_STRING, IDC_MATCH_QUEUE, CTSTRING(MATCH_QUEUE));
menu.AppendMenu(MF_STRING, IDC_PRIVATEMESSAGE, CTSTRING(SEND_PRIVATE_MESSAGE));
menu.AppendMenu(MF_STRING, IDC_ADD_TO_FAVORITES, CTSTRING(ADD_TO_FAVORITES));
menu.AppendMenu(MF_STRING, IDC_GRANTSLOT, CTSTRING(GRANT_EXTRA_SLOT));
menu.AppendMenu(MF_STRING, IDC_REMOVEALL, CTSTRING(REMOVE_FROM_ALL));
}
};
class FlatTabCtrl;
class UserCommand;
template<class T, int title>
class StaticFrame {
public:
~StaticFrame() { frame = NULL; };
static T* frame;
static void openWindow() {
if(frame == NULL) {
frame = new T();
frame->CreateEx(WinUtil::mdiClient, frame->rcDefault, CTSTRING_I(ResourceManager::Strings(title)));
} else {
// match the behavior of MainFrame::onSelected()
HWND hWnd = frame->m_hWnd;
if(frame->MDIGetActive() != hWnd) {
frame->MDIActivate(hWnd);
} else if(BOOLSETTING(TOGGLE_ACTIVE_WINDOW)) {
::SetWindowPos(hWnd, HWND_BOTTOM, 0, 0, 0, 0, SWP_NOACTIVATE | SWP_NOMOVE | SWP_NOSIZE);
frame->MDINext(hWnd);
hWnd = frame->MDIGetActive();
}
if(::IsIconic(hWnd))
::ShowWindow(hWnd, SW_RESTORE);
}
}
};
template<class T, int title>
T* StaticFrame<T, title>::frame = NULL;
class WinUtil {
public:
static CImageList fileImages;
static int fileImageCount;
static CImageList userImages;
typedef HASH_MAP<string, int> ImageMap;
typedef ImageMap::iterator ImageIter;
static ImageMap fileIndexes;
static HBRUSH bgBrush;
static COLORREF textColor;
static COLORREF bgColor;
static HFONT font;
static int fontHeight;
static HFONT boldFont;
static HFONT systemFont;
static HFONT monoFont;
static CMenu mainMenu;
static int dirIconIndex;
static int dirMaskedIndex;
static TStringList lastDirs;
static HWND mainWnd;
static HWND mdiClient;
static FlatTabCtrl* tabCtrl;
static tstring commands;
static HHOOK hook;
static tstring tth;
static StringPairList initialDirs;
static DWORD helpCookie;
static void init(HWND hWnd);
static void uninit();
static void decodeFont(const tstring& setting, LOGFONT &dest);
static void addInitalDir(const User::Ptr& user, string dir) {
// Clear out previos initial dirs, just in case
getInitialDir(user);
while(initialDirs.size() > 30) {
initialDirs.erase(initialDirs.begin());
}
initialDirs.push_back(make_pair(user->getNick(), dir));
}
static string getInitialDir(const User::Ptr& user) {
for(StringPairIter i = initialDirs.begin(); i != initialDirs.end(); ++i) {
if(i->first == user->getNick()) {
string dir = i->second;
initialDirs.erase(i);
return dir;
}
}
return Util::emptyString;
}
static bool getVersionInfo(OSVERSIONINFOEX& ver);
/**
* Check if this is a common /-command.
* @param cmd The whole text string, will be updated to contain only the command.
* @param param Set to any parameters.
* @param message Message that should be sent to the chat.
* @param status Message that should be shown in the status line.
* @return True if the command was processed, false otherwise.
*/
static bool checkCommand(tstring& cmd, tstring& param, tstring& message, tstring& status);
static int getTextWidth(const tstring& str, HWND hWnd) {
HDC dc = ::GetDC(hWnd);
int sz = getTextWidth(str, dc);
::ReleaseDC(mainWnd, dc);
return sz;
}
static int getTextWidth(const tstring& str, HDC dc) {
SIZE sz = { 0, 0 };
::GetTextExtentPoint32(dc, str.c_str(), str.length(), &sz);
return sz.cx;
}
static int getTextHeight(HWND wnd, HFONT fnt) {
HDC dc = ::GetDC(wnd);
int h = getTextHeight(dc, fnt);
::ReleaseDC(wnd, dc);
return h;
}
static int getTextHeight(HDC dc, HFONT fnt) {
HGDIOBJ old = ::SelectObject(dc, fnt);
int h = getTextHeight(dc);
::SelectObject(dc, old);
return h;
}
static int getTextHeight(HDC dc) {
TEXTMETRIC tm;
::GetTextMetrics(dc, &tm);
return tm.tmHeight;
}
static void setClipboard(const tstring& str);
static void addLastDir(const tstring& dir) {
if(find(lastDirs.begin(), lastDirs.end(), dir) != lastDirs.end()) {
return;
}
if(lastDirs.size() == 10) {
lastDirs.erase(lastDirs.begin());
}
lastDirs.push_back(dir);
}
static tstring encodeFont(LOGFONT const& font);
static tstring getHelpFile() {
return Text::toT(Util::getAppPath() + "DCPlusPlus.chm");
}
static bool browseFile(tstring& target, HWND owner = NULL, bool save = true, const tstring& initialDir = Util::emptyStringW, const TCHAR* types = NULL, const TCHAR* defExt = NULL);
static bool browseDirectory(tstring& target, HWND owner = NULL);
// Hash related
static void bitziLink(const TTHValue* /*aHash*/);
static void copyMagnet(const TTHValue* /*aHash*/, const tstring& /*aFile*/);
static void searchHash(const TTHValue* /*aHash*/);
// URL related
static void registerDchubHandler();
static void registerADChubHandler();
static void registerMagnetHandler();
static void parseDchubUrl(const tstring& /*aUrl*/);
static void parseADChubUrl(const tstring& /*aUrl*/);
static void parseMagnetUri(const tstring& /*aUrl*/, bool aOverride = false);
static bool parseDBLClick(const tstring& /*aString*/, string::size_type start, string::size_type end);
static int textUnderCursor(POINT p, CEdit& ctrl, tstring& x);
static void openLink(const tstring& url);
static void openFile(const tstring& file) {
::ShellExecute(NULL, NULL, file.c_str(), NULL, NULL, SW_SHOWNORMAL);
}
static int getIconIndex(const tstring& aFileName);
static int getDirIconIndex() { return dirIconIndex; }
static int getDirMaskedIndex() { return dirMaskedIndex; }
static int getOsMajor();
static int getOsMinor();
static bool getUCParams(HWND parent, const UserCommand& cmd, StringMap& sm) throw();
static void splitTokens(int* array, const string& tokens, int maxItems = -1) throw();
static void saveHeaderOrder(CListViewCtrl& ctrl, SettingsManager::StrSetting order,
SettingsManager::StrSetting widths, int n, int* indexes, int* sizes) throw();
template<class T> static HWND hiddenCreateEx(T& p) throw() {
HWND active = (HWND)::SendMessage(mdiClient, WM_MDIGETACTIVE, 0, 0);
::LockWindowUpdate(mdiClient);
HWND ret = p.CreateEx(mdiClient);
if(active && ::IsWindow(active))
::SendMessage(mdiClient, WM_MDIACTIVATE, (WPARAM)active, 0);
::LockWindowUpdate(0);
return ret;
}
template<class T> static HWND hiddenCreateEx(T* p) throw() {
return hiddenCreateEx(*p);
}
private:
static int CALLBACK browseCallbackProc(HWND hwnd, UINT uMsg, LPARAM /*lp*/, LPARAM pData);
};
#endif // __WINUTIL_H
/**
* @file
* $Id: WinUtil.h,v 1.44 2005/03/14 14:04:46 arnetheduck Exp $
*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -