تصميم النموذج الشجري treeview لدليل الحسابات بالاكسيس

 دليل-الحسابات

تصميم النموذج الشجري treeview لدليل الحسابات بالاكسيس

تصميم النموذج الشجري treeview لدليل الحسابات بالاكسيس نتناول خطوات تصميم النموذج الشجري في الاكسيس treeview و استدعاء المكتبات البرمجيه اللازمه له و نستعرض كل ذلك علي نموذج دليل ال الحسابات و أيضا مزايا و مشاكل treeview

مميزات تصميم  النموذج الشجري

يعطي النموذج الشجري في اي برنامج شكل تصميم احترافي و سهوله فهم نظام التكويد المراد داخل البرنامج و أيضا سهوله التكويد و سهوله في تنظيم التكويد و سهوله البحث دخل التموذج الشجري

عيوب التصميم  الشجري

مشاكل عند مرحله التكويد بعض المشاكل التي قد تواجهك يجب مراعاه التكويد بشكل المتبع دخل البرنامج بشكل صحيح حيث ان التكويد بشكل غير صحيح في اغلب الاحوال سيؤدي الي انهيار النظام الشجري و أيضا قد يؤدي الي الخلل البرمجي في النموذج الشجري فعلي سبيل المثال يتم ادراج حساب اساسي يندرج تحته حساب فرعي يندرج تحت الحساب الفرعي كود الحاساب فان الكود الاب لكود الحساب هو الحساب الفرعي و ليس الكود الاساسي بينما كود الحساب الاب للكود الفرعي هو كود الحساب الاساسي فاذا حدث خلل في التكويد عن هذا النظام سيحدث مشاكل برمجيه اي يجب بناء دليل الحسابات بشكل صحيح كامل حتي نتمكن من عرض النموذج الشجري لدليل الحسابات

مشاكل اثناء نقل ملف العمل بين جهاز و اخر

حيث باختلاف نسخ الاوفيس بين الاجهزه قد تظهر  مشاكل المكتبات البرمجيه و ذلك في حاله نقل البرنامج لجهاز اخر يمكنك التعرف علي حل هذه المشاكل من هنا

خطوات تصميم النموذج الشجري treeview لدليل الحسابات بالاكسيس

تصميم جدول التكويد

في البدايه سنحتاج الي تصميم جدول الاساسيه لتكويد الحسابات المستخدمه دخل النموذج الشجري و المراد عرضها و يتم ذلك من خلال الضغط علي القائمه Create و اختيار منها Table Design دعنا نفترض في حالتنا اننا نريد عمل دليل حسابات بالنموذج الشجري لسهوله تكويد الحسابات و أيضا لسهوله البحث عن الحسابات نستعرض حقول هذا الجدول و اهم خصائص هذه الحقول

 

دليل حسابات

 

Fied SizeDate TypeCaptionField Name
15Textكود الحسابAccID
255Textاسم الحسابArAccDes
15Textكود الحساب الابParAcc
255Textاسم الحساب الابArParDes
—-Yes/NOهل هو حساب رئيسىIsPrimary
15Textمستوى الحسابAccLevel
25Textالتوجية المحاسبىAccdir
15Textطبيعة الرصيدPanat
15Textكود المجموعة الفرعيةكود المجموعة الفرعية

 

لاحظ أيضا ان حقل كود الحساب و الذي افترضنا له اسم AccID تم اعطاءه خاصيه متفتاح اساسي Primary Key نقوم بحفظ الجدول و تعطيه اسم افتراضي accounts

انشاء نماذج العرض

الان نقوم باستخدام معالج النماذج في انشاء نموذج للجدول التكويد من خلال الضغط علي القائمه Create و اختيار منها Form Wizard يمكنك أيضا انشاء النموذج بوضع التصميم و اضافه الحقول بشكل يدوي

 

معالج تصميم النماذج

اضافه النموذج الشجري للنموذج TreeView

و بعد الانتهاء من بناء النموذج ندخل الي النموذج في وضع التصميم لاضافه النموذج الشجري

من خلال القائمه Design اضغط علي زر More كما هو في الصوره  و اختر ActiveX Control , و من خلال هذا المعالج ابحث عن Microsoft TreeView Control  سيقوم المعالج باضافه النموذج الشجري للنموذج

اضافه الاكواد الازمه لاستعراض شجره الحسابات

الان بدا في اضافه الاكواد الازمه لاستعراض شجره الحسابات

Private Sub Form_Load()

On Error Resume Next
 
Dim dbs As dao.Database, rst As dao.Recordset
  Dim nodX As Node
  Set dbs = CurrentDb
  Set rst = dbs.OpenRecordset("Accounts", dbOpenDynaset)
  Set nodX = TreeView2.Nodes.Add(, , "A", "Accounts")
  With rst
    Do While Not .EOF
      Set nodX = TreeView2.Nodes.Add("A" & CStr(Nz(!ParAcc)), tvwChild, "A" & CStr(!AccID), CStr(!AccID) & ":" & (!ArAccDes))
       nodX.EnsureVisible
        .MoveNext
    Loop
  End With
  rst.Close
  Set dbs = Nothing
  On Error Resume Next
  For Each nodX In TreeView2.Nodes
   nodX.Expanded = False
   nodX.Sorted = True
  Next
  
End Sub

استدعاء المكتبه البرمجيه dao

في هذا الكود قمنا باستدعاء المكتبه البرمجيه dao  هذه المكتبه و هي المكتبه الخاصه بالتحكم في قواعد البيانات حيث تستطيع هذه المكتبه البرمجيه انشاء قاعده بيانات و الدخول الي الصفوف و الدوران بين هذه الصفوف و استدعاء القيم من بينها و التحكم بها

قمنا نانشاء متغير من النوع Database و اضفنا له عنصر التحكم dao

Dim dbs As dao.Database 
 rst As dao.Recordse

اضفنا هذا السطر للدوران بين صفوف قاعده البيانات و التحكم بها

 

Set rst = dbs.OpenRecordset(“Accounts”, dbOpenDynaset) Set nodX = TreeView2.Nodes.Add(, , “A”, “Accounts”)

من خلال هذا السطر قمنا بفتح قاعده البيانات التي افترضنها كمتغير و أيضا قمنا بتعبئه محتوياتها في النموذج الشجري TreeView

تم اعطاء راس النموذج الشجري اسم Accounts يمكنك تغير الاسم كيف تشاء

With rst
    Do While Not .EOF
      Set nodX = TreeView2.Nodes.Add("A" & CStr(Nz(!ParAcc)), tvwChild, "A" & CStr(!AccID), CStr(!AccID) & ":" & (!ArAccDes))
       nodX.EnsureVisible
        .MoveNext
    Loop
  End With
  rst.Close

 

فهم خطوات عمل الكود

من خلال هذا الكود تبدا المكتبه البرمجيه dao في الدوران علي قاعده البيانات علي شكل حلقه تكراريه من النوع Do While و تحديد كل عنصر من عناصر هذه القائمه و تحديد مستوي هذا العنصر تبدا بالدوران بدايه من اول صف في قاعده البيانات ليظهر في النموذج الشجري في المستوي المناسب مضاف اليه كود الحساب و الوصف الخاص بالحساب ( اسم الحاب ) ثم يدور الكود علي العنصر التالي بالامر MoveNext و هكذا و يتكرر هذا الامر باستخدام الامر Loop حتي تنتقل الي اخر صف و الانتقال بين جميع الصفوف و بعد الانتهاء يتم الخروج من هذه الحلقه التكراريه End With

استدعاء اسماء الحسابات في النموذج الشجري

لاستدعاء اسم الحساب من جدول الحسابات نستخدم الداله DLookup حيث تقوم هذه الداله بالبحث في جدول accounts في عمود ArAccDes الخاص باسم الحساب و استراج اسم الحساب من بين كل الحسابات بشرط كود الحساب AccID=ParAcc

Private Sub ParAcc_AfterUpdate()

On Error Resume Next
ArParDes = DLookup("ArAccDes", "accounts", "AccID=ParAcc")
End Sub

 

 

Private Sub TreeView2_NodeClick(ByVal Node As Object)
On Error Resume Next
  Dim mykey As String
    With Node
     mykey = Right(.Key, Len(.Key) - 1)
     Finder (mykey)
    End With
End Sub

 

 

Private Sub Finder(Skey)
On Error Resume Next
Dim rs As Object
 Me.Filter = ""
 Set rs = Me.Recordset.Clone
 rs.FindFirst "[AccID] = '" & Trim(Skey) & "'"
 Me.Bookmark = rs.Bookmark
End Sub

 

يمكنك أيضا مشاهده

تصميم شريط ريبون احترافي في الاكسيس – بايقونات احترافيه و أيضا تحميل ملف العمل

مشاكل نقل ملفات قواعد البيانات بين الاجهز و طرق حلها

يمكنك أيضا التعرف علي ايقاف الحفظ التلقائي في الاكسيس

يمكنك أيضا تحميل برنامج كاشير المحال التجاريه بالاكسيس

اترك تعليقاً

لن يتم نشر عنوان بريدك الإلكتروني. الحقول الإلزامية مشار إليها بـ *