تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
جعل مفتاح انتر يعمل عمل مفتاح تاب مع الداتا جريد فيو
#1
السلام عليكم ورحمة الله وبركاته
عرضت محتويات جدول في dgv مفتاح tab ينتقل من خلية لأخرى
مفتاح Enter يأخذ خلية لأسفل أو يأخذ سجل جديد
وللتسهيل على المستخدم في تعديل بيانات الخلايا ..
فلا بد من جعل مفتاح Enter ينتقل إلى الخلية المجاورة فإن لم يجد ينزل لأول خليه في السجل التالي ... أي يعمل عمل مفتاح tab
جربت هذا الكود في حدث ال keydown للداتا جريد فيو
If e.KeyCode = Keys.Enter Then

My.Computer.Keyboard.SendKeys("{Tab}")

End If
لكنه لم يفلح وكذلك جربت الكود ده كمان
If e.KeyCode = Keys.Enter Then
SendKeys.Send("{TAB}")
e.Handled = True
End If
لكنه لم يفلح ...... شكرا لكم
الرد }}}}
تم الشكر بواسطة:
#2
توجد أداة محسنة من DataGridView

قم بإضافة كلاس عن طريق القائمة Project ثم اختيار Add Class ثم ضع هذا الكود فيه
ثم شغل البرنامج مرة وحدة وبعدها تلاقي أداة جديدة في بداية الأدوات ف الاعلى خالص اسمها exDataGridView استخدمها بدل DataGridView
طبعا هي نفسها DataGridView بس مضاف عليها خدمة الانتقال للخلية التالية ب Enter وبالنسبة للانتقال للسطر التالي حيكون Tab وهذه الطريقة الامثل.

منقول من أحد الأعضاء
كود :
Public Class exDataGridView
    Inherits DataGridView

    Protected Overrides Function ProcessDataGridViewKey(ByVal e As KeyEventArgs) As Boolean
        If e.KeyCode = Keys.Enter Then
            Return Me.ProcessRightKey(e.KeyData)
        End If
        Return MyBase.ProcessDataGridViewKey(e)
    End Function

End Class
الرد }}}}
تم الشكر بواسطة:
#3
واذا كنت تبيها زي ما قلت بالضبط "فلا بد من جعل مفتاح Enter ينتقل إلى الخلية المجاورة فإن لم يجد ينزل لأول خليه في السجل التالي" فضع هذا الكود بدل السابق
الحمد لله وجدته وهو أيضا منقول
كود :
Public Class exDataGridView
    Inherits DataGridView

    Protected Overrides Function ProcessDataGridViewKey(ByVal e As KeyEventArgs) As Boolean
        If e.KeyCode = Keys.Enter Then
            If Me.CurrentCell.ColumnIndex = Me.Columns.Count - 1 Then
                Me.CurrentCell = Me.Item(0, Me.CurrentRow.Index)
                Return Me.ProcessEnterKey(e.KeyData)
            Else
                Return Me.ProcessRightKey(e.KeyData)
            End If
        End If
        Return MyBase.ProcessDataGridViewKey(e)
    End Function

End Class
الرد }}}}
تم الشكر بواسطة: thevirus
#4
شكرا اخي MsDos
الرد }}}}
تم الشكر بواسطة:
#5
طلع فيه تعديل أخير وهو الأفضل (المعذرة)

كود :
Public Class exDataGridView
    Inherits DataGridView

    Protected Overrides Function ProcessDialogKey(ByVal keyData As Keys) As Boolean
        Dim key As Keys = (keyData And Keys.KeyCode)
        If key = Keys.Enter Then
            If Me.CurrentCell.ColumnIndex = Me.Columns.Count - 1 Then
                Me.CurrentCell = Me.Item(0, Me.CurrentRow.Index)
                Return Me.ProcessDownKey(keyData)
            Else
                Return Me.ProcessRightKey(keyData)
            End If
        End If
        Return MyBase.ProcessDialogKey(keyData)
    End Function

    Protected Overrides Function ProcessDataGridViewKey(ByVal e As KeyEventArgs) As Boolean
        If e.KeyCode = Keys.Enter Then
            If Me.CurrentCell.ColumnIndex = Me.Columns.Count - 1 Then
                Me.CurrentCell = Me.Item(0, Me.CurrentRow.Index)
                Return Me.ProcessDownKey(e.KeyData)
            Else
                Return Me.ProcessRightKey(e.KeyData)
            End If
        End If
        Return MyBase.ProcessDataGridViewKey(e)
    End Function

End Class
الرد }}}}
تم الشكر بواسطة: thevirus , العواد الصغير
#6
السادة الكرام
الكود ممتاز فيما لوكان اتجاه الداتا فيو من اليسار لليمن
أما اذا كان اتجاهها من اليمين لليسار فلا يصلح الكود لهذه المهمة
هل يمكن تعديل الكود
جزاكم الله كل خير
الرد }}}}
تم الشكر بواسطة:
#7
أخوي... إبحث في الكلمة سوف تجد كلمة Right غيرها إلى Left.....

أخوي... إبحث في الكود سوف تجد كلمة Right غيرها إلى Left.....
اخي استفد من الاكواد بتعديلها بما يحقق مطلبك
الرد }}}}
تم الشكر بواسطة:
#8
اخي الكريم السرور
جزاك الله كل خير
نجح الامر
الرد }}}}
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  ازاى يبقى الصفوف فى الداتا جريد فيو مترتبة زى اللى فى الداتا بيز اكسس بالظبط araxis 2 64 01-12-16, 07:04 AM
آخر رد: araxis
  كيف يتم حل مشكلة ظهور رسالة عند الضغط علي هيد داتا جريد فيو السيد الجوهري 4 50 30-11-16, 10:08 PM
آخر رد: السيد الجوهري
  التحقق من وجود هذة القيمة فى الداتا جريد فيو مع العلم انى استخدم المعالج araxis 4 168 29-11-16, 07:26 AM
آخر رد: amgad525
  الداتا ببتلغبط لما الكمبيوتر بيتفطع عنة الكهربا مرة واحدة araxis 5 120 22-11-16, 06:42 PM
آخر رد: zinom
  [VB.NET] ربط الداتا بيز بالكريستال ريبورت عن طريق الكود thevirus 3 93 22-11-16, 02:38 PM
آخر رد: thevirus
  كيف اتعامل مع الداتا اقرد فيو واستخدامها في التقارير معتز الجازوي 1 58 17-11-16, 11:53 AM
آخر رد: Genius Live
  كيف اتعامل مع الداتا اقرد فيو واستخدامها في التقارير معتز الجازوي 1 89 15-11-16, 12:41 PM
آخر رد: محمود بكرى
  فحص لــ القيمة المدخلة فى حقل مفتاح رئيسى Unique Key ل datagridview noway 6 133 15-11-16, 09:06 AM
آخر رد: noway
  استدعاء داتا من الداتا بيز عن طريق المعالج araxis 14 275 15-11-16, 07:17 AM
آخر رد: araxis
  [VB.NET] تفريغ داتا جريد tifagreet 5 102 09-11-16, 07:06 PM
آخر رد: thevirus

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


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