امتیاز موضوع:
  • 0 رأی - میانگین امتیازات: 0
  • 1
  • 2
  • 3
  • 4
  • 5
گرفتن ورودی از کارت کپچر در VB
نویسنده پیام
mehdi_shz11 آفلاین
تازه وارد

ارسال‌ها: 13
موضوع‌ها: 7
تاریخ عضویت: شهریور ۱۳۸۶

تشکرها : 0
( 3 تشکر در 3 ارسال )
ارسال: #1
گرفتن ورودی از کارت کپچر در VB
سلام.
من یه پروژه ای دارم که توی اون باید از کارت کپچرم تو VB ورودی بگیرم.
من خیلی به VB وارد نیستم ، الانم نمی دونم چیکار کنم . ممنون میشم راهنماییم کنین.
ممنونم.
۲۹-آبان-۱۳۸۸, ۰۳:۳۹:۱۲
ارسال‌ها
پاسخ
vblove آفلاین
كاربر دو ستاره
**

ارسال‌ها: 155
موضوع‌ها: 9
تاریخ عضویت: اردیبهشت ۱۳۸۴

تشکرها : 0
( 19 تشکر در 10 ارسال )
ارسال: #2
RE: گرفتن ورودی از کارت کپچر در VB
سلام دوست عزیز

کارت کپچر رو که نصب میکنی احتمالا چن تا فایل دی ال ال یا ocx به سیستم شما اضافه میشه

که باید از آنها استفاده کنی . البته یه کم مشکل هست این کار .

۱۹-دى-۱۳۸۹, ۲۰:۱۹:۳۰
وب سایت ارسال‌ها
پاسخ
modj.ir آفلاین
كاربر دو ستاره
**

ارسال‌ها: 233
موضوع‌ها: 0
تاریخ عضویت: شهریور ۱۳۸۸

تشکرها : 1
( 547 تشکر در 230 ارسال )
ارسال: #3
RE: گرفتن ورودی از کارت کپچر در VB
درود بر پاسخ نچندان صحیح شما بعد از 1 سال و 1 ماهو نیم

۱۹-دى-۱۳۸۹, ۲۳:۴۶:۴۶
وب سایت ارسال‌ها
پاسخ
behzadX آفلاین
كاربر دو ستاره
**

ارسال‌ها: 73
موضوع‌ها: 11
تاریخ عضویت: دى ۱۳۸۵

تشکرها : 83
( 84 تشکر در 47 ارسال )
ارسال: #4
RE: گرفتن ورودی از کارت کپچر در VB
سلام
توسط برنامه Filemon میتونی به راحتی با اجرای برنامه کاربردی کارت کپچر فایلهایی که توسط برنامه مورد استفاده قرار می گیرد رو پیدا کنی و با استفاده از توابع اونا در ویژوال بیسیک از کارت استفاده کنی . استفاده از وب کم تو وی بی آسونه خدا کنه اینم همون طور باشه .
اگه نتونستی با فایل ها کار کنی یا اینکه توی توابع اون به مشکل خوردی کافی توی گوگل اسم فایل رو بنویسی و به زبان اصلی دنبال راهنمای استفاده از فایل بگردی حتما پیدا می کنی .
موفق باشی.

هم اکنون نیازمند یاری سبزتان هستیم
گروه دوبلاژ بازی ایران ویج
از کابرانی که علاقه به دوبلاژ بازی دارند دعوت به همکاری می نماید.
با نظرات خود ما را در این امر یاری نمایید.
026
۲۰-دى-۱۳۸۹, ۰۰:۰۰:۳۱
ارسال‌ها
پاسخ
modj.ir آفلاین
كاربر دو ستاره
**

ارسال‌ها: 233
موضوع‌ها: 0
تاریخ عضویت: شهریور ۱۳۸۸

تشکرها : 1
( 547 تشکر در 230 ارسال )
ارسال: #5
RE: گرفتن ورودی از کارت کپچر در VB
استفاده از وب کم و کارت کپچر استاندارد به یک شکل هست. تفاوتی ( توو استاندارد ها مثل ماوس HID ) نداره

۲۰-دى-۱۳۸۹, ۰۱:۱۵:۱۸
وب سایت ارسال‌ها
پاسخ
iranvigforme آفلاین
تازه وارد

ارسال‌ها: 7
موضوع‌ها: 2
تاریخ عضویت: بهمن ۱۳۹۰

تشکرها : 0
( 1 تشکر در 1 ارسال )
ارسال: #6
RE: گرفتن ورودی از کارت کپچر در VB
سلام به دوستان
واسه این کار چندین راه وجود داره.
یکی از این راه ها استفاده از توابع یه dll تو windows به نام avicap32.dll هست.
راه های دیگه و بهتر استفاده از توابع directx وdirectshow هست.
راه دیگه ای هم هست که البته مختص webcam هست و اون برنامه نویسی از روش wiaاست.
واسه اولین راه یه source جمع و جور میذارم
امیدوارم موفق باشید.
کد:
[align=left]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 ' Current device ID

Dim hHwnd As Integer ' Handle to preview window


Declare Function SendMessage Lib "user32" Alias "SendMessageA" _


(ByVal hwnd As Integer, ByVal wMsg As Integer, ByVal wParam As Integer, _


<MarshalAs(UnmanagedType.AsAny)> 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 Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load


LoadDeviceList()


If lstDevices.Items.Count > 0 Then



btnStart.Enabled = True



lstDevices.SelectedIndex = 0



btnStart.Enabled = True


Else



lstDevices.Items.Add("No Capture Device")



btnStart.Enabled = False


End If


btnStop.Enabled = False


btnSave.Enabled = False


'picCapture.SizeMode = PictureBoxSizeMode.StretchImage


picCapture.SizeMode = PictureBoxSizeMode.AutoSize



End Sub


Private Sub LoadDeviceList()


Dim strName As String = Space(100)


Dim strVer As String = Space(100)


Dim bReturn As Boolean


Dim x As Integer = 0



'


' Load name of all avialable devices into the lstDevices


'



Do



'



' Get Driver name and version



'



bReturn = capGetDriverDescriptionA(x, strName, 100, strVer, 100)




'



' If there was a device add device name to the list



'



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



'


' Open Preview window in picturebox


'


hHwnd = capCreateCaptureWindowA(iDevice, WS_VISIBLE Or WS_CHILD, 0, 0, 640, _



480, picCapture.Handle.ToInt32, 0)



'


' Connect to device


'


If SendMessage(hHwnd, WM_CAP_DRIVER_CONNECT, iDevice, 0) Then



'



'Set the preview scale



'



SendMessage(hHwnd, WM_CAP_SET_SCALE, True, 0)




'



'Set the preview rate in milliseconds



'



SendMessage(hHwnd, WM_CAP_SET_PREVIEWRATE, 66, 0)




'



'Start previewing the image from the camera



'



SendMessage(hHwnd, WM_CAP_SET_PREVIEW, True, 0)




'



' Resize window to fit in picturebox



'



SetWindowPos(hHwnd, HWND_BOTTOM, 0, 0, 640, 480, _





SWP_NOMOVE Or SWP_NOZORDER)




btnSave.Enabled = True



btnStop.Enabled = True



btnStart.Enabled = False


Else



'



' Error connecting to device close window



'



DestroyWindow(hHwnd)




btnSave.Enabled = False


End If

End Sub


Private Sub btnStart_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnStart.Click


iDevice = lstDevices.SelectedIndex


OpenPreviewWindow()

End Sub


Private Sub ClosePreviewWindow()


'


' Disconnect from device


'


SendMessage(hHwnd, WM_CAP_DRIVER_DISCONNECT, iDevice, 0)



'


' close window


'



DestroyWindow(hHwnd)

End Sub


Private Sub btnStop_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnStop.Click


ClosePreviewWindow()


btnSave.Enabled = False


btnStart.Enabled = True


btnStop.Enabled = False

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



'


' Copy image to clipboard


'


SendMessage(hHwnd, WM_CAP_EDIT_COPY, 640, 480)



'


' Get image from clipboard and convert it to a bitmap


'


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[/align]
(آخرین ویرایش در این ارسال: ۱۳-اسفند-۱۳۹۰, ۰۱:۳۵:۵۵، توسط Payman62.)
۱۱-اسفند-۱۳۹۰, ۱۵:۲۱:۰۵
ارسال‌ها
پاسخ
تشکر شده توسط : Di Di


موضوعات مرتبط با این موضوع...
موضوع نویسنده پاسخ بازدید آخرین ارسال
  گرفتن متن فارسی و نمایش آن از فایل متنی GTAexcess 2 3,065 ۱۳-اردیبهشت-۱۳۹۵, ۱۴:۰۸:۴۷
آخرین ارسال: Ghoghnus
  مشکل ماژول گرفتن اطلاعات سیستم hossein161 1 2,792 ۲۰-شهریور-۱۳۹۴, ۱۵:۲۲:۲۲
آخرین ارسال: Payman62
  [سوال] گرفتن شماره ستون و ردیف از رنج مشخص به شکل داینامیک eppagh 0 2,162 ۰۶-اسفند-۱۳۹۳, ۲۰:۱۸:۱۳
آخرین ارسال: eppagh
  کمک برای گرفتن خروجی در EXCEL javad917 4 5,369 ۱۵-آبان-۱۳۹۳, ۱۴:۵۸:۵۴
آخرین ارسال: javad917
  مشکل در تماس گرفتن MSComm mahdi321 3 4,039 ۰۶-فروردین-۱۳۹۳, ۱۹:۴۶:۲۸
آخرین ارسال: Ghoghnus
  گرفتن سورس سایت aleas 6 5,415 ۲۷-شهریور-۱۳۹۲, ۱۴:۰۴:۴۰
آخرین ارسال: rap0661
Question [سوال] گرفتن آیپی سایت megatron 6 5,209 ۲۱-تير-۱۳۹۲, ۲۳:۵۴:۳۲
آخرین ارسال: megatron
  گرفتن عکس از هر جایی که دلت بخواد skh1300 2 3,473 ۱۲-اسفند-۱۳۹۱, ۱۷:۳۸:۳۰
آخرین ارسال: setroyd
  گرفتن Ignore List snoopboy 9 8,079 ۲۷-آبان-۱۳۹۱, ۲۱:۳۶:۱۳
آخرین ارسال: *spring
  هک سیم کارت VisualBasic6Love 21 31,501 ۱۲-اسفند-۱۳۹۰, ۰۳:۰۱:۰۰
آخرین ارسال: robojalal

پرش به انجمن:


کاربرانِ درحال بازدید از این موضوع: 1 مهمان

صفحه‌ی تماس | IranVig | بازگشت به بالا | | بایگانی | پیوند سایتی RSS