📄 queueframe.h
字号:
/*
* Copyright (C) 2001-2003 Jacek Sieka, j_s@telia.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.
*/
#if !defined(AFX_QUEUEFRAME_H__8F6D05EC_ADCF_4987_8881_6DF3C0E355FA__INCLUDED_)
#define AFX_QUEUEFRAME_H__8F6D05EC_ADCF_4987_8881_6DF3C0E355FA__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include "FlatTabCtrl.h"
#include "ExListViewCtrl.h"
#include "../client/QueueManager.h"
#include "../client/CriticalSection.h"
#define SHOWTREE_MESSAGE_MAP 12
class QueueFrame : public MDITabChildWindowImpl<QueueFrame>, private QueueManagerListener, public CSplitterImpl<QueueFrame>
{
public:
enum {
IDC_BROWSELIST = 3000,
IDC_REMOVE_SOURCE = 3400,
IDC_PM = 3600,
IDC_READD = 3800,
IDC_PRIORITY_PAUSED = 4000,
IDC_PRIORITY_LOWEST,
IDC_PRIORITY_LOW,
IDC_PRIORITY_NORMAL,
IDC_PRIORITY_HIGH,
IDC_PRIORITY_HIGHEST
};
DECLARE_FRAME_WND_CLASS_EX("QueueFrame", IDR_QUEUE, 0, COLOR_3DFACE);
static QueueFrame* frame;
QueueFrame() : menuItems(0), queueSize(0), queueItems(0), spoken(false), dirty(false),
usingDirMenu(false), readdItems(0), fileLists(NULL), showTree(true), closed(false),
showTreeContainer("BUTTON", this, SHOWTREE_MESSAGE_MAP)
{
searchFilter.push_back("the");
searchFilter.push_back("of");
searchFilter.push_back("divx");
searchFilter.push_back("frail");
}
virtual ~QueueFrame() { }
virtual void OnFinalMessage(HWND /*hWnd*/) {
delete this;
}
typedef MDITabChildWindowImpl<QueueFrame> baseClass;
typedef CSplitterImpl<QueueFrame> splitBase;
BEGIN_MSG_MAP(QueueFrame)
MESSAGE_HANDLER(WM_CREATE, OnCreate)
MESSAGE_HANDLER(WM_CLOSE, onClose)
MESSAGE_HANDLER(WM_SPEAKER, onSpeaker)
MESSAGE_HANDLER(WM_CONTEXTMENU, onContextMenu)
MESSAGE_HANDLER(WM_SETFOCUS, onSetFocus)
NOTIFY_HANDLER(IDC_QUEUE, LVN_COLUMNCLICK, onColumnClick)
NOTIFY_HANDLER(IDC_QUEUE, LVN_KEYDOWN, onKeyDown)
NOTIFY_HANDLER(IDC_QUEUE, LVN_ITEMCHANGED, onItemChangedQueue)
NOTIFY_HANDLER(IDC_DIRECTORIES, TVN_SELCHANGED, onItemChanged)
NOTIFY_HANDLER(IDC_DIRECTORIES, TVN_KEYDOWN, onKeyDownDirs)
COMMAND_ID_HANDLER(IDC_SEARCH_ALTERNATES, onSearchAlternates)
COMMAND_ID_HANDLER(IDC_REMOVE, onRemove)
COMMAND_ID_HANDLER(IDC_MOVE, onMove)
COMMAND_RANGE_HANDLER(IDC_PRIORITY_PAUSED, IDC_PRIORITY_HIGHEST, onPriority)
COMMAND_RANGE_HANDLER(IDC_BROWSELIST, IDC_BROWSELIST + menuItems, onBrowseList)
COMMAND_RANGE_HANDLER(IDC_REMOVE_SOURCE, IDC_REMOVE_SOURCE + menuItems, onRemoveSource)
COMMAND_RANGE_HANDLER(IDC_PM, IDC_PM + menuItems, onPM)
COMMAND_RANGE_HANDLER(IDC_READD, IDC_READD + readdItems, onReadd)
CHAIN_MSG_MAP(splitBase)
CHAIN_MSG_MAP(baseClass)
ALT_MSG_MAP(SHOWTREE_MESSAGE_MAP)
MESSAGE_HANDLER(BM_SETCHECK, onShowTree)
END_MSG_MAP()
LRESULT onPriority(WORD /*wNotifyCode*/, WORD wID, HWND /*hWndCtl*/, BOOL& /*bHandled*/);
LRESULT onBrowseList(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/);
LRESULT onRemoveSource(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/);
LRESULT onPM(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/);
LRESULT onReadd(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/);
LRESULT onSearchAlternates(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/);
LRESULT onItemChanged(int idCtrl, LPNMHDR pnmh, BOOL& bHandled);
LRESULT onContextMenu(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM lParam, BOOL& bHandled);
LRESULT onSpeaker(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM lParam, BOOL& bHandled);
LRESULT OnCreate(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM /*lParam*/, BOOL& bHandled);
LRESULT OnChar(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
LRESULT onClose(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM /*lParam*/, BOOL& bHandled);
void UpdateLayout(BOOL bResizeBars = TRUE);
void removeDir(HTREEITEM ht);
void setPriority(HTREEITEM ht, const QueueItem::Priority& p);
LRESULT onItemChangedQueue(int /*idCtrl*/, LPNMHDR pnmh, BOOL& /*bHandled*/) {
NMLISTVIEW* lv = (NMLISTVIEW*)pnmh;
if((lv->uNewState & LVIS_SELECTED) != (lv->uOldState & LVIS_SELECTED))
updateStatus();
return 0;
}
LRESULT onSetFocus(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM /*lParam*/, BOOL& /* bHandled */) {
ctrlQueue.SetFocus();
return 0;
}
LRESULT onRemove(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
usingDirMenu ? removeSelectedDir() : removeSelected();
return 0;
}
LRESULT onMove(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/) {
usingDirMenu ? moveSelectedDir() : moveSelected();
return 0;
}
LRESULT onKeyDown(int /*idCtrl*/, LPNMHDR pnmh, BOOL& /*bHandled*/) {
NMLVKEYDOWN* kd = (NMLVKEYDOWN*) pnmh;
if(kd->wVKey == VK_DELETE) {
removeSelected();
} else if(kd->wVKey == VK_TAB) {
onTab();
}
return 0;
}
LRESULT onKeyDownDirs(int /*idCtrl*/, LPNMHDR pnmh, BOOL& /*bHandled*/) {
NMTVKEYDOWN* kd = (NMTVKEYDOWN*) pnmh;
if(kd->wVKey == VK_TAB) {
onTab();
}
return 0;
}
void onTab() {
if(showTree) {
HWND focus = ::GetFocus();
if(focus == ctrlDirs.m_hWnd) {
ctrlQueue.SetFocus();
} else if(focus == ctrlQueue.m_hWnd) {
ctrlDirs.SetFocus();
}
}
}
static int sortSize(LPARAM a, LPARAM b) {
QueueItem* c = (QueueItem*)a;
QueueItem* d = (QueueItem*)b;
return compare(c->getSize(), d->getSize());
}
static int sortPriority(LPARAM a, LPARAM b) {
QueueItem* c = (QueueItem*)a;
QueueItem* d = (QueueItem*)b;
return compare(c->getPriority(), d->getPriority());
}
LRESULT onColumnClick(int /*idCtrl*/, LPNMHDR pnmh, BOOL& /*bHandled*/) {
NMLISTVIEW* l = (NMLISTVIEW*)pnmh;
if(l->iSubItem == ctrlQueue.getSortColumn()) {
ctrlQueue.setSortDirection(!ctrlQueue.getSortDirection());
} else {
if(l->iSubItem == COLUMN_SIZE) {
ctrlQueue.setSort(l->iSubItem, ExListViewCtrl::SORT_FUNC, true, sortSize);
} else if(l->iSubItem == COLUMN_PRIORITY) {
ctrlQueue.setSort(l->iSubItem, ExListViewCtrl::SORT_FUNC, true, sortPriority);
} else {
ctrlQueue.setSort(l->iSubItem, ExListViewCtrl::SORT_STRING_NOCASE);
}
}
return 0;
}
LRESULT onShowTree(UINT /*uMsg*/, WPARAM wParam, LPARAM /*lParam*/, BOOL& bHandled) {
bHandled = FALSE;
showTree = (wParam == BST_CHECKED);
UpdateLayout(FALSE);
return 0;
}
private:
enum {
COLUMN_FIRST,
COLUMN_TARGET = COLUMN_FIRST,
COLUMN_STATUS,
COLUMN_SIZE,
COLUMN_PRIORITY,
COLUMN_USERS,
COLUMN_PATH,
COLUMN_ERRORS,
COLUMN_LAST
};
enum Tasks {
ADD_ITEM,
REMOVE_ITEM,
SET_TEXT
};
class StringListInfo;
friend class StringListInfo;
class StringListInfo {
public:
StringListInfo(QueueItem* aQi);
string columns[COLUMN_LAST];
};
typedef pair<Tasks, void*> Task;
typedef list<Task> TaskList;
typedef TaskList::iterator TaskIter;
TaskList tasks;
bool spoken;
/** Single selection in the queue part */
CMenu singleMenu;
/** Multiple selection in the queue part */
CMenu multiMenu;
/** Tree part menu */
CMenu browseMenu;
CMenu removeMenu;
CMenu pmMenu;
CMenu priorityMenu;
CMenu readdMenu;
CMenu dirMenu;
CButton ctrlShowTree;
CContainedWindow showTreeContainer;
bool showTree;
bool usingDirMenu;
bool dirty;
int menuItems;
int readdItems;
HTREEITEM fileLists;
StringList searchFilter;
string commonStart;
typedef hash_map<QueueItem*, QueueItem*, PointerHash<QueueItem> > QueueMap;
typedef QueueMap::iterator QueueIter;
QueueMap queue;
typedef HASH_MULTIMAP<string, QueueItem*, noCaseStringHash, noCaseStringEq> DirectoryMap;
typedef DirectoryMap::iterator DirectoryIter;
typedef pair<DirectoryIter, DirectoryIter> DirectoryPair;
DirectoryMap directories;
string curDir;
CriticalSection cs;
ExListViewCtrl ctrlQueue;
CTreeViewCtrl ctrlDirs;
CStatusBarCtrl ctrlStatus;
int statusSizes[6];
int64_t queueSize;
int queueItems;
bool closed;
static int columnIndexes[COLUMN_LAST];
static int columnSizes[COLUMN_LAST];
void addQueueList(const QueueItem::StringMap& l);
void addQueueItem(QueueItem* qi);
HTREEITEM addDirectory(const string& dir, bool isFileList = false);
void removeDirectory(const string& dir, bool isFileList = false);
void removeDirectories(HTREEITEM ht);
void updateQueue();
void updateStatus();
/**
* This one is different from the others because when a lot of files are removed
* at the same time, the WM_SPEAKER messages seem to get lost in the handling or
* something, they're not correctly processed anyway...thanks windows.
*/
void speak(Tasks t, void* p) {
Lock l(cs);
tasks.push_back(make_pair(t, p));
if(!spoken) {
PostMessage(WM_SPEAKER);
spoken = true;
}
}
void moveSelected();
void moveSelectedDir();
void moveDir(HTREEITEM ht, const string& target);
void moveNode(HTREEITEM item, HTREEITEM parent);
void clearTree(HTREEITEM item) {
HTREEITEM next = ctrlDirs.GetChildItem(item);
while(next != NULL) {
clearTree(next);
next = ctrlDirs.GetNextSiblingItem(next);
}
delete (string*)ctrlDirs.GetItemData(item);
}
void removeSelected() {
int i = -1;
while( (i = ctrlQueue.GetNextItem(i, LVNI_SELECTED)) != -1) {
QueueManager::getInstance()->remove(((QueueItem*)ctrlQueue.GetItemData(i))->getTarget());
}
}
void removeSelectedDir() { removeDir(ctrlDirs.GetSelectedItem()); };
const string& getSelectedDir() {
HTREEITEM ht = ctrlDirs.GetSelectedItem();
return ht == NULL ? Util::emptyString : getDir(ctrlDirs.GetSelectedItem());
};
const string& getDir(HTREEITEM ht) { dcassert(ht != NULL); return *((string*)ctrlDirs.GetItemData(ht)); };
virtual void onAction(QueueManagerListener::Types type, QueueItem* aQI) throw();
void onQueueAdded(QueueItem* aQI);
void onQueueMoved(QueueItem* aQI);
void onQueueRemoved(QueueItem* aQI);
void onQueueUpdated(QueueItem* aQI);
};
#endif // !defined(AFX_QUEUEFRAME_H__8F6D05EC_ADCF_4987_8881_6DF3C0E355FA__INCLUDED_)
/**
* @file
* $Id: QueueFrame.h,v 1.18 2003/07/15 14:53:12 arnetheduck Exp $
*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -