تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[سؤال] كيف ألتقط صورة من الكامرة إلى البكتشر بكس
#1
أرجوكم إخواني ساعدوني
أريد هذا الكود ضروري
الرد
تم الشكر بواسطة:
#2
السلام عليكم 
اخذت كوبي من الفورم لضيق وقتي فقط 
كود :
Public Class Form1
   Const WM_CAP As Short = &H400S
   Const WM_CAP_DRIVER_CONNECT As Integer = WM_CAP + 10
   Const WM_CAP_DRIVER_DISCONNECT As Integer = WM_CAP + 11
   Const WM_CAP_EDIT_COPY As Integer = WM_CAP + 30
   Const WM_CAP_SET_PREVIEW As Integer = WM_CAP + 50
   Const WM_CAP_SET_PREVIEWRATE As Integer = WM_CAP + 52
   Const WM_CAP_SET_SCALE As Integer = WM_CAP + 53
   Const WS_CHILD As Integer = &H40000000
   Const WS_VISIBLE As Integer = &H10000000
   Const SWP_NOMOVE As Short = &H2S
   Const SWP_NOSIZE As Short = 1
   Const SWP_NOZORDER As Short = &H4S
   Const HWND_BOTTOM As Short = 1
   Dim iDevice As Integer = 0
   Dim hHwnd As Integer
   Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Integer, ByVal wMsg As Integer, ByVal wParam As Integer, ByVal lParam As OBJECT) As Integer
   Declare Function SetWindowPos Lib "user32" Alias "SetWindowPos" (ByVal hwnd As Integer, ByVal hWndInsertAfter As Integer, ByVal x As Integer, ByVal y As Integer, ByVal cx As Integer, ByVal cy As Integer, ByVal wFlags As Integer) As Integer
   Declare Function DestroyWindow Lib "user32" (ByVal hndw As Integer) As Boolean
   Declare Function capCreateCaptureWindowA Lib "avicap32.dll" (ByVal lpszWindowName As String, ByVal dwStyle As Integer, ByVal x As Integer, ByVal y As Integer, ByVal nWidth As Integer, ByVal nHeight As Short, ByVal hWndParent As Integer, ByVal nID As Integer) As Integer
   Declare Function capGetDriverDescriptionA Lib "avicap32.dll" (ByVal wDriver As Short, ByVal lpszName As String, ByVal cbName As Integer, ByVal lpszVer As String, ByVal cbVer As Integer) As Boolean

   Private Sub LoadDeviceList()
       Dim strName As String = Space(100)
       Dim strVer As String = Space(100)
       Dim bReturn As Boolean
       Dim x As Integer = 0
       Do
           bReturn = capGetDriverDescriptionA(x, strName, 100, strVer, 100)
           If bReturn Then lstDevices.Items.Add(strName.Trim)
           x += 1
       Loop Until bReturn = False
   End Sub

   Private Sub OpenPreviewWindow()
       Dim iHeight As Integer = picCapture.Height
       Dim iWidth As Integer = picCapture.Width
       hHwnd = capCreateCaptureWindowA(iDevice, WS_VISIBLE Or WS_CHILD, 0, 0, 640, 480, picCapture.Handle.ToInt32, 0)
       If SendMessage(hHwnd, WM_CAP_DRIVER_CONNECT, iDevice, 0) Then
           SendMessage(hHwnd, WM_CAP_SET_SCALE, True, 0)
           SendMessage(hHwnd, WM_CAP_SET_PREVIEWRATE, 66, 0)
           SendMessage(hHwnd, WM_CAP_SET_PREVIEW, True, 0)
           SetWindowPos(hHwnd, HWND_BOTTOM, 0, 0, picCapture.Width, picCapture.Height, SWP_NOMOVE Or SWP_NOZORDER)
           btnSave.Enabled = True
           btnStop.Enabled = True
           btnStart.Enabled = False
       Else
           DestroyWindow(hHwnd)
           btnSave.Enabled = False
       End If
   End Sub

   Private Sub btnSave_Click(ByVal sender As System.OBJECT, ByVal e As System.EventArgs) Handles btnSave.Click
       Dim data As IDataObject
       Dim bmap As Image
       SendMessage(hHwnd, WM_CAP_EDIT_COPY, 0, 0)
       data = Clipboard.GetDataObject()
       If data.GetDataPresent(GetType(System.Drawing.Bitmap)) Then
           bmap = CType(data.GetData(GetType(System.Drawing.Bitmap)), Image)
           picCapture.Image = bmap
           ClosePreviewWindow()
           btnSave.Enabled = False
           btnStop.Enabled = False
           btnStart.Enabled = True
           If sfdImage.ShowDialog = DialogResult.OK Then
               bmap.Save(sfdImage.FileName, Imaging.ImageFormat.Bmp)
           End If
       End If
   End Sub

   Private Sub ClosePreviewWindow()
       SendMessage(hHwnd, WM_CAP_DRIVER_DISCONNECT, iDevice, 0)
       DestroyWindow(hHwnd)
   End Sub

   Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
       LoadDeviceList()
   End Sub

   Private Sub btnStart_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnStart.Click
       OpenPreviewWindow()
       btnStart.Enabled = False
       btnStop.Enabled = True
   End Sub

   Private Sub btnStop_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnStop.Click
       ClosePreviewWindow()
       btnStart.Enabled = True
       btnStop.Enabled = False
   End Sub
End Class
microsoft partner
Team administrator
MCPD,MCITP,OCP,MP,MCC
Xprema Systems
الرد
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  عرض صورة رسول555 3 80 14-04-18, 11:06 AM
آخر رد: حريف برمجة
  رسالة عرض صورة رسول555 4 108 10-04-18, 02:48 AM
آخر رد: رسول555
  السادة الافاضل أرجو المساعدة للضرورة القصوة "كود حفظ صورة من ويب كام مباشرة " nohadking 1 78 22-03-18, 11:00 AM
آخر رد: silverlight
  تحديد مركز الدائرة فى صورة mrnooo2000 4 145 06-03-18, 01:56 AM
آخر رد: عبدالله الدوسري
  إضافة صورة iFanfan 0 43 24-02-18, 02:57 AM
آخر رد: iFanfan
  [سؤال] تصدير صورة من السكانر prj 8 2,523 16-02-18, 03:00 PM
آخر رد: issatiger
  [سؤال] سحب صورة من السكانر ؟ Mido9 11 7,725 16-02-18, 02:52 PM
آخر رد: issatiger
  حل للخلفية بصندوق صورة Basil Abdallah 1 35 12-02-18, 07:36 PM
آخر رد: Basil Abdallah
  كيفية اضافة صورة لزر في الداتا قريد فيو المتألق9 2 63 06-02-18, 03:35 PM
آخر رد: المتألق9
  [VB.NET] كيفية عمل برنامج صغير لرفع صورة من جهازي وتحويلها الي رابط e-coder 3 53 04-02-18, 01:23 AM
آخر رد: Basil Abdallah

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم