亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? umshelltree.cpp

?? 中央氣象臺(tái)與日本臺(tái)風(fēng)數(shù)據(jù)之間的格式轉(zhuǎn)換程序
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
// UmShellTree.cpp : implementation file
//

#include "stdafx.h"
#include "UmShellTree.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CUmShellTree
//
// This source is part of CUmShellTree - Selom Ofori
// 
// Version: 1.02 (any previously unversioned copies are older/inferior
//
// This code is free for all to use. Mutatilate it as much as you want
// See MFCENUM sample from microsoft

CUmShellTree::CUmShellTree()
{
}

CUmShellTree::~CUmShellTree()
{
}


BEGIN_MESSAGE_MAP(CUmShellTree, CTreeCtrl)
	//{{AFX_MSG_MAP(CUmShellTree)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/****************************************************************************
*
*    FUNCTION: PopulateTree()
*
*    PURPOSE:  Processes the File.Fill/RefreshTree command
*
****************************************************************************/
void CUmShellTree::PopulateTree() 
{

    LPSHELLFOLDER lpsf=NULL;
    LPITEMIDLIST  lpi=NULL;
    HRESULT hr;
    TV_SORTCB      tvscb;
   
    // Get a pointer to the desktop folder.
    hr=SHGetDesktopFolder(&lpsf);

    if (SUCCEEDED(hr))
    {
       // Initialize the tree view to be empty.
       DeleteAllItems();

       // Fill in the tree view from the root.
       FillTreeView(lpsf, NULL, TVI_ROOT);
       //TunnelFillTree(lpsf, NULL, TVI_ROOT);
       // Release the folder pointer.
       lpsf->Release();
    }
    tvscb.hParent     = TVI_ROOT;
    tvscb.lParam      = 0;
    tvscb.lpfnCompare = TreeViewCompareProc;

    // Sort the items in the tree view
	SortChildrenCB(&tvscb/*, FALSE*/);
    
	HTREEITEM hItem;
	hItem = GetRootItem();
	hItem = GetNextSiblingItem(hItem);
	Expand(hItem,TVE_EXPAND);
	Select(hItem/*GetRootItem()*/,TVGN_CARET);
}

/****************************************************************************
*
*	FUNCTION:	PopulateTree()
*
*	PURPOSE:	Processes the File.Fill/RefreshTree command
*				This overload  has the ability to open from a
*				special folderlocation like SHBrowseForFolder()
*
*	WARNING:	TunnelTree() will not work if you use a special
*				folderlocation
*
****************************************************************************/
void CUmShellTree::PopulateTree(int nFolder) 
{

	LPSHELLFOLDER lpsf=NULL,lpsf2=NULL;
    LPITEMIDLIST  lpi=NULL;
    HRESULT hr;
    TV_SORTCB      tvscb;
   
    // Get a pointer to the desktop folder.
	hr=SHGetDesktopFolder(&lpsf);

    if (SUCCEEDED(hr))
    {
       // Initialize the tree view to be empty.
		DeleteAllItems();

		if (!SUCCEEDED(SHGetSpecialFolderLocation( 
				m_hWnd, nFolder, &lpi))) 
		{ 
			lpi=NULL;
			FillTreeView(lpsf,NULL,TVI_ROOT);
		}
		else
		{
			hr=lpsf->BindToObject(lpi,
                0, IID_IShellFolder,(LPVOID *)&lpsf2);

			if(SUCCEEDED(hr))
			{
				// Fill in the tree view from the root.
				FillTreeView(lpsf2, lpi, TVI_ROOT);
				lpsf2->Release();
			}
			else
				FillTreeView(lpsf,NULL,TVI_ROOT);
		}

		// Release the folder pointer.
		lpsf->Release();
	}
    tvscb.hParent     = TVI_ROOT;
    tvscb.lParam      = 0;
    tvscb.lpfnCompare = TreeViewCompareProc;

    // Sort the items in the tree view
	SortChildrenCB(&tvscb/*, FALSE*/);
    
	HTREEITEM hItem;
	hItem = GetRootItem();
	Expand(hItem,TVE_EXPAND);
	Select(GetRootItem(),TVGN_CARET);
}

/****************************************************************************
*
*  FUNCTION: FillTreeView( LPSHELLFOLDER lpsf,
*                          LPITEMIDLIST  lpifq,
*                          HTREEITEM     hParent)
*
*  PURPOSE: Fills a branch of the TreeView control.  Given the
*           shell folder, enumerate the subitems of this folder,
*           and add the appropriate items to the tree.
*
*  PARAMETERS:
*    lpsf         - Pointer to shell folder that we want to enumerate items 
*    lpifq        - Fully qualified item id list to the item that we are enumerating
*                   items for.  In other words, this is the PIDL to the item
*                   identified by the lpsf parameter.
*    hParent      - Parent node
*
*  COMMENTS:
*    This function enumerates the items in the folder identifed by lpsf.
*    Note that since we are filling the left hand pane, we will only add
*    items that are folders and/or have sub-folders.  We *could* put all
*    items in here if we wanted, but that's not the intent.
*
****************************************************************************/
void CUmShellTree::FillTreeView(LPSHELLFOLDER lpsf, LPITEMIDLIST  lpifq, HTREEITEM     hParent)
{
    TV_ITEM         tvi;                          // TreeView Item.
    TV_INSERTSTRUCT tvins;                        // TreeView Insert Struct.
    HTREEITEM       hPrev = NULL;                 // Previous Item Added.
    LPSHELLFOLDER   lpsf2=NULL;
    LPENUMIDLIST    lpe=NULL;
    LPITEMIDLIST    lpi=NULL, lpiTemp=NULL, lpifqThisItem=NULL;
    LPTVITEMDATA    lptvid=NULL;
    LPMALLOC        lpMalloc=NULL;
    ULONG           ulFetched;
    UINT            uCount=0;
    HRESULT         hr;
    char            szBuff[256];
    HWND            hwnd=::GetParent(m_hWnd);

    // Allocate a shell memory object. 
    hr=::SHGetMalloc(&lpMalloc);
    if (FAILED(hr))
       return;

    if (SUCCEEDED(hr))
    {
        // Get the IEnumIDList object for the given folder.
        hr=lpsf->EnumObjects(hwnd, SHCONTF_FOLDERS | SHCONTF_NONFOLDERS, &lpe);

        if (SUCCEEDED(hr))
        {
            // Enumerate throught the list of folder and non-folder objects.
            while (S_OK==lpe->Next(1, &lpi, &ulFetched))
            {
                //Create a fully qualified path to the current item
                //The SH* shell api's take a fully qualified path pidl,
                //(see GetIcon above where I call SHGetFileInfo) whereas the
                //interface methods take a relative path pidl.
                ULONG ulAttrs = SFGAO_HASSUBFOLDER | SFGAO_FOLDER;

                // Determine what type of object we have.
                lpsf->GetAttributesOf(1, (const struct _ITEMIDLIST **)&lpi, &ulAttrs);

                if (ulAttrs & (SFGAO_HASSUBFOLDER | SFGAO_FOLDER))
                {
                   //We need this next if statement so that we don't add things like
                   //the MSN to our tree.  MSN is not a folder, but according to the
                   //shell it has subfolders.
                   if (ulAttrs & SFGAO_FOLDER)
                   {
                      tvi.mask= TVIF_TEXT | TVIF_IMAGE | TVIF_SELECTEDIMAGE | TVIF_PARAM;

                      if (ulAttrs & SFGAO_HASSUBFOLDER)
                      {
                         //This item has sub-folders, so let's put the + in the TreeView.
                         //The first time the user clicks on the item, we'll populate the
                         //sub-folders.
                         tvi.cChildren=1;
                         tvi.mask |= TVIF_CHILDREN;
                      }
                        
                      //OK, let's get some memory for our ITEMDATA struct
                      lptvid = (LPTVITEMDATA)lpMalloc->Alloc(sizeof(TVITEMDATA));
                      if (!lptvid)
                         goto Done;  // Error - could not allocate memory.
   
                      //Now get the friendly name that we'll put in the treeview.
                      if (!GetName(lpsf, lpi, SHGDN_NORMAL, szBuff))
                         goto Done; // Error - could not get friendly name.

                      tvi.pszText    = szBuff;
                      tvi.cchTextMax = MAX_PATH;
    
                      lpifqThisItem=ConcatPidls(lpifq, lpi);
      
                      //Now, make a copy of the ITEMIDLIST
                      lptvid->lpi=CopyITEMID(lpMalloc, lpi);
   
                      GetNormalAndSelectedIcons(lpifqThisItem, &tvi);
   
                      lptvid->lpsfParent=lpsf;    //Store the parent folders SF
                      lpsf->AddRef();

                      lptvid->lpifq=ConcatPidls(lpifq, lpi);
   
                      tvi.lParam = (LPARAM)lptvid;
   
                      // Populate the TreeVeiw Insert Struct
                      // The item is the one filled above.
                      // Insert it after the last item inserted at this level.
                      // And indicate this is a root entry.
                      tvins.item         = tvi;
                      tvins.hInsertAfter = hPrev;
                      tvins.hParent      = hParent;
   
                      // Add the item to the tree
                      hPrev = InsertItem(&tvins);
                   }
                   // Free this items task allocator.
                   lpMalloc->Free(lpifqThisItem);  
                   lpifqThisItem=0;
                }

                lpMalloc->Free(lpi);  //Free the pidl that the shell gave us.
                lpi=0;
            }
        }

    }
    else
       return;

Done:
 
    if (lpe)  
        lpe->Release();

    //The following 2 if statements will only be TRUE if we got here on an
    //error condition from the "goto" statement.  Otherwise, we free this memory
    //at the end of the while loop above.
    if (lpi && lpMalloc)           
        lpMalloc->Free(lpi);
    if (lpifqThisItem && lpMalloc) 
        lpMalloc->Free(lpifqThisItem);  

    if (lpMalloc) 
        lpMalloc->Release();
}


/****************************************************************************
*
*    FUNCTION: GetNormalAndSelectedIcons(LPITEMIDLIST lpifq, LPTV_ITEM lptvitem)
*
*    PURPOSE:  Gets the index for the normal and selected icons for the current item.
*
*    PARAMETERS:
*    lpifq    - Fully qualified item id list for current item.
*    lptvitem - Pointer to treeview item we are about to add to the tree.
*
****************************************************************************/
void CUmShellTree::GetNormalAndSelectedIcons(LPITEMIDLIST lpifq,
                               LPTV_ITEM lptvitem)
{
   //Note that we don't check the return value here because if GetIcon()
   //fails, then we're in big trouble...

   lptvitem->iImage = GetItemIcon(lpifq, SHGFI_PIDL | 
                              SHGFI_SYSICONINDEX | 
                              SHGFI_SMALLICON);
   
   lptvitem->iSelectedImage = GetItemIcon(lpifq, SHGFI_PIDL | 
                                      SHGFI_SYSICONINDEX | 
                                      SHGFI_SMALLICON |
                                      SHGFI_OPENICON);
   
   return;
}



/****************************************************************************
*
*    FUNCTION: TreeViewCompareProc(LPARAM, LPARAM, LPARAM)
*
*    PURPOSE:  Callback routine for sorting the tree 
*
****************************************************************************/
int CALLBACK CUmShellTree::TreeViewCompareProc(LPARAM lparam1, 
    LPARAM lparam2, LPARAM lparamSort)
{
    LPTVITEMDATA lptvid1=(LPTVITEMDATA)lparam1;
    LPTVITEMDATA lptvid2=(LPTVITEMDATA)lparam2;
    HRESULT   hr;

    hr = lptvid1->lpsfParent->CompareIDs(0,lptvid1->lpi,lptvid2->lpi);

    if (FAILED(hr))
       return 0;

    return (short)SCODE_CODE(GetScode(hr));
}




/////////////////////////////////////////////////////////////////////////////
// CUmShellTree message handlers

/****************************************************************************
*
*	FUNCTION:	OnFolderExpanding(NMHDR* pNMHDR, LRESULT* pResult) 
*
*	PURPOSE:	Reponds to an TVN_ITEMEXPANDING message in order to fill up
*				subdirectories. Pass the parameters from OnItemExpanding() to 
*				this function. You need to do that or your folders won't
*				expand.
*
*	OTHER:		It can also be used to update a corresponding listview. Seem MFCENUM
*
*	MESSAGEMAP:	TVN_ITEMEXPANDING
*
****************************************************************************/
void CUmShellTree::OnFolderExpanding(NMHDR* pNMHDR, LRESULT* pResult) 
{
	LPTVITEMDATA   lptvid;  //Long pointer to TreeView item data
	HRESULT        hr;
	LPSHELLFOLDER  lpsf2=NULL;
	static char    szBuff[MAX_PATH];
	TV_SORTCB      tvscb;

	NM_TREEVIEW* pnmtv = (NM_TREEVIEW*)pNMHDR;
	// TODO: Add your control notification handler code here
    if ((pnmtv->itemNew.state & TVIS_EXPANDEDONCE))
         return;
		
    lptvid=(LPTVITEMDATA)pnmtv->itemNew.lParam;
    if (lptvid)
       {
            hr=lptvid->lpsfParent->BindToObject(lptvid->lpi,
                0, IID_IShellFolder,(LPVOID *)&lpsf2);

            if (SUCCEEDED(hr))
            {
                FillTreeView(lpsf2,
                       lptvid->lpifq,
                       pnmtv->itemNew.hItem);
            }

            tvscb.hParent     = pnmtv->itemNew.hItem;
            tvscb.lParam      = 0;
            tvscb.lpfnCompare = TreeViewCompareProc;

            SortChildrenCB(&tvscb /*, FALSE*/);
    }	
	
	*pResult = 0;
}

/****************************************************************************
*
*	FUNCTION:	GetContextMenu(NMHDR* pNMHDR, LRESULT* pResult) 
*
*	PURPOSE:	Diplays a popup menu for the folder selected. Pass the
*				parameters from Rclick() to this function.
*
*	MESSAGEMAP:	NM_RCLICK;
*
****************************************************************************/
void CUmShellTree::GetContextMenu(NMHDR* pNMHDR, LRESULT* pResult) 

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本大道久久a久久精品综合| 国产欧美一区在线| 欧美日韩激情在线| 欧美四级电影网| 欧美精三区欧美精三区| 欧美电影一区二区三区| 91精品久久久久久久久99蜜臂| 欧美日韩精品一区二区在线播放| 欧美日韩国产综合一区二区| 欧美另类高清zo欧美| 欧美日韩成人综合| 日韩一二三区不卡| 欧美一级日韩不卡播放免费| 精品88久久久久88久久久| 国产丝袜美腿一区二区三区| 中文字幕一区二区在线观看| 国产精品入口麻豆原神| 夜夜嗨av一区二区三区网页| 午夜精品爽啪视频| 狠狠色综合播放一区二区| 粉嫩绯色av一区二区在线观看| fc2成人免费人成在线观看播放| 91麻豆国产福利在线观看| 欧美丝袜丝nylons| 欧美成人一区二区三区片免费 | 337p亚洲精品色噜噜噜| 91精品国产综合久久福利软件| 日韩精品资源二区在线| 国产精品女上位| 亚洲成精国产精品女| 国产一区二区三区四区五区美女| 成人激情免费视频| 欧美精品亚洲一区二区在线播放| 久久先锋影音av鲁色资源网| 中文字幕亚洲精品在线观看| 日韩国产欧美在线视频| 国产91露脸合集magnet| 欧美在线观看一区| 久久影院电视剧免费观看| 亚洲精品久久嫩草网站秘色| 美女网站一区二区| 91在线视频官网| 精品久久一二三区| 艳妇臀荡乳欲伦亚洲一区| 久久99久久精品欧美| 91黄色在线观看| 久久久美女毛片| 亚洲一区二区三区国产| 国产成人亚洲精品青草天美| 欧美视频在线一区| 国产精品青草综合久久久久99| 亚洲一二三四在线| 国产aⅴ综合色| 欧美一级一区二区| 亚洲情趣在线观看| 国产精一品亚洲二区在线视频| 在线视频你懂得一区二区三区| 欧美精品一区二区三区蜜桃| 亚洲成人自拍一区| 99精品欧美一区| 久久久久久影视| 日韩高清一级片| 91丨九色丨蝌蚪富婆spa| 精品国产一区二区在线观看| 亚洲一区二区欧美| 91精品国产福利在线观看| 亚洲欧美综合网| 国产成人亚洲精品青草天美| 91精品国产手机| 亚洲第一主播视频| 99v久久综合狠狠综合久久| 久久久蜜桃精品| 久久不见久久见免费视频1| 欧美性极品少妇| 亚洲免费观看在线视频| 国产精华液一区二区三区| 日韩精品综合一本久道在线视频| 亚洲国产精品一区二区www在线| 成人av资源下载| 国产婷婷色一区二区三区四区| 日韩av不卡一区二区| 在线观看国产日韩| 亚洲免费av高清| av不卡免费在线观看| 久久综合中文字幕| 奇米精品一区二区三区在线观看| 欧美日韩国产首页在线观看| 一区二区久久久久| 色婷婷综合久色| 一区二区三区四区亚洲| 不卡一区二区中文字幕| 国产免费成人在线视频| 国产成人免费视| 国产亚洲一区二区三区在线观看| 极品少妇xxxx偷拍精品少妇| 精品久久久久一区二区国产| 免费人成网站在线观看欧美高清| 欧美日韩成人综合| 日韩电影在线观看网站| 91精品国产一区二区三区| 免费人成精品欧美精品| 日韩欧美国产三级| 免费成人小视频| 欧美成人bangbros| 国产一区二区三区黄视频| 2021中文字幕一区亚洲| 国产伦精品一区二区三区免费 | 亚洲日本在线视频观看| 99久久综合国产精品| 亚洲色图视频网站| 色噜噜狠狠一区二区三区果冻| 亚洲摸摸操操av| 欧美日韩国产综合一区二区| 日韩电影在线看| 久久久一区二区三区捆绑**| 成熟亚洲日本毛茸茸凸凹| 亚洲欧美色一区| 欧美蜜桃一区二区三区| 久久成人综合网| 亚洲国产精品v| 色av成人天堂桃色av| 亚洲午夜免费福利视频| 日韩一区二区视频| 国产成人av电影免费在线观看| 中文字幕亚洲电影| 欧美日韩mp4| 国产一区二区在线观看免费| 中文字幕一区免费在线观看| 欧美视频中文字幕| 精品中文字幕一区二区小辣椒| 久久久蜜桃精品| 色综合久久六月婷婷中文字幕| 日韩精品久久久久久| 久久久99免费| 欧美在线观看视频一区二区| 69堂国产成人免费视频| 激情欧美日韩一区二区| 国产精品成人免费精品自在线观看| 在线观看日产精品| 狠狠久久亚洲欧美| 亚洲免费av在线| 欧美成人伊人久久综合网| 99精品欧美一区二区三区小说| 婷婷开心激情综合| 国产精品欧美精品| 欧美剧情片在线观看| 国产精一区二区三区| 亚洲福利国产精品| 久久久久久久免费视频了| 欧美午夜精品免费| 国产aⅴ综合色| 日韩成人免费电影| 综合激情网...| 欧美成人精品高清在线播放| 99re热这里只有精品视频| 久久99精品国产91久久来源| 亚洲人123区| 久久久久久久av麻豆果冻| 色欧美乱欧美15图片| 国产成人综合在线播放| 奇米精品一区二区三区在线观看| 亚洲视频一区二区在线| 亚洲精品一区二区三区影院 | 久久久国产一区二区三区四区小说| 日本精品视频一区二区| 国产精品亚洲一区二区三区妖精| 亚洲成a人片在线观看中文| 国产精品久久久久久久久搜平片 | 精品国产一区二区在线观看| 在线观看日韩国产| 9久草视频在线视频精品| 久久99精品国产麻豆不卡| 亚洲动漫第一页| 亚洲日本电影在线| 欧美激情一区三区| 精品噜噜噜噜久久久久久久久试看| 91搞黄在线观看| 91在线国产福利| 风间由美中文字幕在线看视频国产欧美| 五月婷婷另类国产| 亚洲女性喷水在线观看一区| 国产丝袜美腿一区二区三区| 日韩精品一区二区三区四区| 欧美剧情电影在线观看完整版免费励志电影 | 看国产成人h片视频| 亚洲成在线观看| 亚洲韩国一区二区三区| 亚洲精品视频自拍| 一区视频在线播放| 国产精品国产自产拍高清av| 欧美高清在线视频| 久久久精品免费网站| 久久免费的精品国产v∧| 日韩欧美国产一区二区在线播放| 欧美丰满少妇xxxxx高潮对白| 欧美日韩亚洲综合一区二区三区| 色婷婷av一区二区三区之一色屋| a亚洲天堂av| 色琪琪一区二区三区亚洲区| 一本色道久久综合亚洲91|