- tarik
- عدد المساهمات : 134
تاريخ التسجيل : 08/10/2012
مراقبة الملفات الموجودة في الحافظة Clipboard
الخميس أكتوبر 18, 2012 8:51 pm
في بعض الاحيان قد تحتاج الى كتابة كود لمراقبة الملفات الموجودة في الحافظة Clipboard ، وأدنى ما تحتاجه غالبا هو معرفة المسار الكامل للملف والعملية ادت الى وضع الملف في الحافظة سواء كانت نسخ copy او قص Cut ، قد تتخيل لوهلة أن العملية قد تكون معقدة وصعبة للغاية ، لكن دعني اخبرك بان الكائن My.computer.clipboard الخاص بالتعامل مع حافظة النظام يحتوي على طرق Methods تسهل معرفه محتوى الحافظة سواء كان صوت او نص او ملفات ، فلنتابع معا الفكرة التي اقتبستها من احد المواقع الاجنبية .
الطريقة GetFileDropList تعود لنا بـ Collection تمثل قائمة بالملفات الموجودة في الذاكرة ، وسيكون بإمكاننا بسهوله كتابة كود كالتالي للحصول عليها في اداة TextBox متعددة الاسطر:
للحصول على نوع الاجراء Drop Effect Type، سنقوم بعمل كائن من النوع Object ونسند له القيمة:
السطور التالية توضح ذلك :
الطريقة GetFileDropList تعود لنا بـ Collection تمثل قائمة بالملفات الموجودة في الذاكرة ، وسيكون بإمكاننا بسهوله كتابة كود كالتالي للحصول عليها في اداة TextBox متعددة الاسطر:
- الكود:
If My.Computer.Clipboard.ContainsFileDropList = True Then
Dim FileNameCollection As Collections.Specialized.StringCollection = _
My.Computer.Clipboard.GetFileDropList()
For Each FileName As String In FileNameCollection
TextBox1.AppendText(FileName & vbNewLine)
Next
End If
للحصول على نوع الاجراء Drop Effect Type، سنقوم بعمل كائن من النوع Object ونسند له القيمة:
- الكود:
My.Computer.Clipboard.GetData("Preferred DropEffect")
السطور التالية توضح ذلك :
- الكود:
Dim DropEffectData(3) As Byte
Dim DropEffectCheck As Object = _
My.Computer.Clipboard.GetData("Preferred DropEffect")
DropEffectCheck.Read(DropEffectData, 0, DropEffectData.Length)
- الكود:
‘*>——————————————————————-
‘*>Handle Droplist
‘*>——————————————————————-
If My.Computer.Clipboard.ContainsFileDropList() Then
‘*>——————————————————————-
‘*>Get DropEffect Type
‘*>——————————————————————-
Dim DropEffectData(3) As Byte
Dim DropEffectCheck As Object = _
My.Computer.Clipboard.GetData("Preferred DropEffect")
DropEffectCheck.Read(DropEffectData, 0, DropEffectData.Length)
Dim DropEff As DragDropEffects
Dim DropEffType As String
Select Case DropEffectData(0)
Case 2
DropEff = DragDropEffects.Move
DropEffType = "Move"
Case 5
DropEff = DragDropEffects.Copy
DropEffType = "Copy"
Case Else
DropEffType = "???"
End Select
DropEffect.Text = DropEffType
‘*>——————————————————————-
‘*>Get File Names
‘*>——————————————————————-
Dim FileNameCollection As Collections.Specialized.StringCollection = _
My.Computer.Clipboard.GetFileDropList()
For Each FileName As String In FileNameCollection
DataText.AppendText(FileName & vbNewLine)
Next
End If
صلاحيات هذا المنتدى:
لاتستطيع الرد على المواضيع في هذا المنتدى