• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 224  文章 - 41  trackbacks - 0
            <2008年11月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            享受編程

            常用鏈接

            留言簿(11)

            隨筆分類(159)

            隨筆檔案(224)

            文章分類(2)

            文章檔案(4)

            經典c++博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             原文地址:http://www.cnblogs.com/AndyHai/archive/2007/07/25/830224.html

            有同學向我問這個問題,于是就Google了一下找到答案,不過是C下的,我將其改編成了C#的。

              當設備被插入/拔出的時候,WINDOWS會向每個窗體發送WM_DEVICECHANGE 消息,當消息的wParam 值等于 DBT_DEVICEARRIVAL 時,表示Media設備被插入并且已經可用;如果wParam值等于DBT_DEVICEREMOVECOMPLETE,表示Media設備已經被移出。

            它們的lParam都指向一個 DEV_BROADCAST_HDR結構體,其原形如下:

            typedef struct _DEV_BROADCAST_HDR
            {
                 DWORD dbch_size;
                 DWORD dbch_devicetype;
                 DWORD dbch_reserved;
            }
             DEV_BROADCAST_HDR, *PDEV_BROADCAST_HDR;

            這個結構體僅僅是一個“頭”(HDR),其后還有附加數據,dbch_size表示結構體實例的字節數,當其中的dbch_devicetype字段值等于DBT_DEVTYP_VOLUME時,表示當前設備是邏輯驅動器,且lParam實際上指向的應該是DEV_BROADCAST_VOLUME 結構體實例(真佩服這種邏輯),DEV_BROADCAST_VOLUME 結構體原形如下:

            typedef struct _DEV_BROADCAST_VOLUME
            {
                DWORD dbcv_size;
                DWORD dbcv_devicetype;
                DWORD dbcv_reserved;
                DWORD dbcv_unitmask;
                WORD dbcv_flags;
            }
             DEV_BROADCAST_VOLUME, *PDEV_BROADCAST_VOLUME;

            其中dbcv_unitmask 字段表示當前改變的驅動器掩碼,第一位表示驅動器號A,第二位表示驅動器號B,第三位表示驅動器號C,以此類推…… dbcv_flags 表示驅動器的類別,如果等于1,則是光盤驅動器;如果是2,則是網絡驅動器;如果是硬盤、U盤則都等于0

              所以,我只需要在程序中捕捉WM_DEVICECHANGE 消息,然后根據具體情況去處理即可,下面是我的測試代碼:


            using System;
            using System.Runtime.InteropServices;
            using System.Collections.Generic;
            using System.ComponentModel;
            using System.Data;
            using System.Drawing;
            using System.Text;
            using System.Windows.Forms;

            namespace UDiskDetect
            {
                
            public partial class Form1 : Form
                
            {
                    
            public Form1()
                    
            {
                        InitializeComponent();
                    }


                    
            private void Form1_Load(object sender, EventArgs e)
                    
            {

                    }


                    [StructLayout(LayoutKind.Sequential)]
                    
            struct DEV_BROADCAST_HDR
                    
            {
                        
            public UInt32 dbch_size;
                        
            public UInt32 dbch_devicetype;
                        
            public UInt32 dbch_reserved;
                    }


                    [StructLayout(LayoutKind.Sequential)]
                    
            struct DEV_BROADCAST_VOLUME
                    
            {
                        
            public UInt32 dbcv_size;
                        
            public UInt32 dbcv_devicetype;
                        
            public UInt32 dbcv_reserved;
                        
            public UInt32 dbcv_unitmask;
                        
            public UInt16 dbcv_flags;
                    }


                    
            protected override void DefWndProc(ref Message m)
                    
            {
                        
            if (m.Msg == 0x0219)//WM_DEVICECHANGE
                        {
                            
            switch (m.WParam.ToInt32())
                            
            {
                                
            case 0x8000://DBT_DEVICEARRIVAL
                                    {
                                        DEV_BROADCAST_HDR dbhdr 
            = (DEV_BROADCAST_HDR)Marshal.PtrToStructure(m.LParam, typeof(DEV_BROADCAST_HDR));

                                        
            if (dbhdr.dbch_devicetype == 0x00000002)//DBT_DEVTYP_VOLUME
                                        {
                                            DEV_BROADCAST_VOLUME dbv 
            = (DEV_BROADCAST_VOLUME)Marshal.PtrToStructure(m.LParam, typeof(DEV_BROADCAST_VOLUME));
                                            
            if (dbv.dbcv_flags == 0)
                                                AddVolumes(GetVolumes(dbv.dbcv_unitmask));
                                        }

                                        
            break;
                                    }

                                
            case 0x8004://DBT_DEVICEREMOVECOMPLETE
                                    {
                                        DEV_BROADCAST_HDR dbhdr 
            = (DEV_BROADCAST_HDR)Marshal.PtrToStructure(m.LParam, typeof(DEV_BROADCAST_HDR));

                                        
            if (dbhdr.dbch_devicetype == 0x00000002)//DBT_DEVTYP_VOLUME
                                        {
                                            DEV_BROADCAST_VOLUME dbv 
            = (DEV_BROADCAST_VOLUME)Marshal.PtrToStructure(m.LParam, typeof(DEV_BROADCAST_VOLUME));
                                            
            if (dbv.dbcv_flags == 0)
                                                RemoveVolumes(GetVolumes(dbv.dbcv_unitmask));
                                        }

                                        
            break;
                                    }

                            }

                        }

                        
            base.DefWndProc(ref m);
                    }


                    
            /**//// <summary>
                    
            /// 根據驅動器掩碼返回驅動器號數組
                    
            /// </summary>
                    
            /// <param name="Mask">掩碼</param>
                    
            /// <returns>返回驅動器號數組</returns>

                    public static char[] GetVolumes(UInt32 Mask)
                    
            {
                        List
            <char> Volumes = new List<char>();

                        
            for (int i = 0; i < 32; i++)
                        
            {
                            
            uint p = (uint)Math.Pow(2, i);
                            
            if ((p | Mask) == p)
                            
            {
                                Volumes.Add((
            char)('A' + i));
                            }

                        }


                        
            return Volumes.ToArray();
                    }


                    
            public void AddVolumes(char[] Volumes)
                    
            {
                        
            foreach (char volume in Volumes)
                            listBox1.Items.Add(volume);
                    }


                    
            public void RemoveVolumes(char[] Volumes)
                    
            {
                        
            foreach (char volume in Volumes)
                            listBox1.Items.Remove(volume);
                    }


                }

            }
            ps:Retrieving dbcc_name string from a DEV_BROADCAST_DEVICEINTERFACE structure
            原文地址:http://bytes.com/topic/c-sharp/answers/244829-retrieving-dbcc_name-string-dev_broadcast_deviceinterface-structure


            posted on 2010-09-16 13:41 漂漂 閱讀(1502) 評論(0)  編輯 收藏 引用 所屬分類: c#開發
            久久丫精品国产亚洲av不卡| 久久一区二区三区免费| 欧美精品乱码99久久蜜桃| 久久亚洲精品国产精品婷婷| 亚洲va久久久噜噜噜久久男同| 久久AV高清无码| 久久精品国产亚洲7777| 综合久久国产九一剧情麻豆 | 久久久久久国产精品免费免费| 日韩AV毛片精品久久久| 精品国产乱码久久久久久1区2区| 久久综合久久久| 久久影院综合精品| 久久久久久久综合狠狠综合| 2021久久精品国产99国产精品| 日韩欧美亚洲综合久久影院Ds| 粉嫩小泬无遮挡久久久久久 | 亚洲AV无码久久寂寞少妇| 国产成人久久精品麻豆一区| 久久综合狠狠综合久久| 久久强奷乱码老熟女网站| 久久精品国产亚洲AV高清热| 色天使久久综合网天天| 国产精品美女久久久网AV| 久久99国产乱子伦精品免费| 99久久这里只精品国产免费| 久久久久亚洲爆乳少妇无| 国产午夜精品久久久久九九| 久久精品aⅴ无码中文字字幕重口| 香蕉99久久国产综合精品宅男自 | 国产精品成人无码久久久久久 | 久久精品九九亚洲精品| 中文字幕无码精品亚洲资源网久久| 无码人妻久久一区二区三区蜜桃| 国产精品女同一区二区久久| 99精品国产在热久久无毒不卡 | 久久精品无码av| 久久久久四虎国产精品| 久久狠狠色狠狠色综合| 欧美日韩中文字幕久久伊人| 91久久国产视频|