परिचय।
माइक्रोसॉफ्ट एक्सेस लिस्ट व्यू कंट्रोल प्रोजेक्ट को ट्री व्यू कंट्रोल ट्यूटोरियल के इस एपिसोड में डिजाइन और प्रदर्शित किया गया है। मुख्य कार्य है, पहले उत्पाद की श्रेणी वस्तुओं के साथ ट्री व्यू कंट्रोल को पॉप्युलेट करें। फिर ट्री व्यू कंट्रोल पर एक श्रेणी आइटम के चयन पर, संबंधित उत्पाद रिकॉर्ड्स को उत्पाद तालिका से फ़िल्टर किया गया है और सूची दृश्य नियंत्रण में सूचीबद्ध किया गया है। प्रत्येक रिकॉर्ड के फ़ील्ड मान अलग-अलग कॉलम में प्रदर्शित किए जा रहे हैं।
हम TreeView, ImageList, और ImageCombo नियंत्रणों से परिचित हैं और पहले के एपिसोड में उनके साथ काम किया है।
ListView Control तीन अलग-अलग फ़ील्ड से डेटा को तीन अलग-अलग कॉलम में प्रदर्शित करेगा। कॉलम में कॉलम हेडर और अन्य कॉलम गुण होंगे, जैसे रिपोर्ट आइकन, टूलटिप टेक्स्ट .
उत्पाद रिकॉर्ड में कई फ़ील्ड हैं और उन सभी को ListView नियंत्रण में प्रदर्शित नहीं किया जा सकता है, जिसमें एक छोटे से क्षेत्र में कई कॉलम हैं। इसके बजाय, जब सूची दृश्य नियंत्रण में किसी आइटम का चयन किया जाता है तो चयनित उत्पाद रिकॉर्ड के पूर्ण विवरण के साथ एक अन्य प्रपत्र खुल जाएगा। संक्षेप में, हम यहां ट्री व्यू, लिस्ट व्यू और इमेजलिस्ट कंट्रोल का उपयोग करके यही करने की योजना बना रहे हैं।
लिस्ट व्यू कंट्रोल प्रॉपर्टीज में माइक्रोसॉफ्ट एक्सेस लिस्टबॉक्स कंट्रोल के समान विशेषताएं हैं। इसमें प्रत्येक कॉलम हेडर के तहत एक दूसरे के बगल में संबंधित मान प्रदर्शित करने के लिए कॉलम होते हैं। कॉलम की चौड़ाई प्रत्येक कॉलम के लिए संपत्ति मूल्य, यह सुनिश्चित करता है कि सामग्री को ठीक से प्रदर्शित करने के लिए फ़ील्ड मान में पर्याप्त स्थान है। ListView आइटम क्लिकों के प्रति प्रतिक्रिया करता है ताकि हम अन्य क्रियाएं कर सकें, जैसे फॉर्म खोलना, रिपोर्ट करना, मैक्रो, या अन्य कार्यों को कॉल करना, यदि आवश्यक हो।
पहले के ट्यूटोरियल सत्रों के लिंक।
- माइक्रोसॉफ्ट ट्री व्यू कंट्रोल ट्यूटोरियल।
- ट्री व्यू कंट्रोल के साथ एक्सेस मेनू बनाना।
- ट्री व्यू कंट्रोल को इमेज असाइन करना।
- ट्रीव्यू कंट्रोल-2 को इमेज असाइन करना, इमेजलिस्ट कंट्रोल को अन्य प्रोजेक्ट्स के साथ शेयर करने योग्य बनाना।
- ट्री व्यू कंट्रोल चेक-मार्क ऐड, डिलीट नोड्स।
- ट्री व्यू इमेजकॉम्बो ड्रॉप-डाउन एक्सेस मेनू।
- ट्री व्यू नोड्स को ड्रैग एंड ड्रॉप द्वारा पुनर्व्यवस्थित करें।
एक्सेस लिस्टबॉक्स कंट्रोल पर लेख।
Microsoft Access में, हम सूचना प्रदर्शित करने और विभिन्न तरीकों से उनका उपयोग करने के लिए ListBox Control का उपयोग कर सकते हैं। कस्टम-निर्मित फॉर्म विज़ार्ड और कस्टम-निर्मित रिपोर्ट विज़ार्ड बनाने के लिए। लिस्टबॉक्स में हाइपरलिंक बनाने के लिए, किसी अन्य लिस्टबॉक्स के स्रोत डेटा से सूची आइटम बनाना, बाहरी फाइलों की सूची को सूची बॉक्स में लाना, या लिस्टबॉक्स में फ़िल्टर () फ़ंक्शन आउटपुट असाइन करना। ये कुछ तरीके थे जिन्हें हमने पहले एक्सेस लिस्टबॉक्स के साथ आजमाया था। संदर्भ के लिए लिंक नीचे दिए गए हैं।
-
कस्टम-निर्मित फॉर्म-विज़ार्ड।
-
कस्टम-निर्मित रिपोर्ट- विज़ार्ड।
-
लिस्टबॉक्स में हाइपरलिंक के साथ फॉर्म खोलें।
-
किसी अन्य लिस्टबॉक्स से सूची बनाएं।
-
डायनामिक लिस्टबॉक्स कॉम्बोबॉक्स सामग्री।
-
लिस्टबॉक्स में फंक्शन आउटपुट को फ़िल्टर करें।
-
ListBox-2 में फंक्शन आउटपुट को फ़िल्टर करें
-
सूची-बॉक्स और दिनांक भाग-एक।
-
सूची-बॉक्स और दिनांक भाग-दो।
ट्री व्यू कंट्रोल डेमो इमेज के साथ लिस्ट व्यू।
ट्री व्यू और लिस्ट व्यू कंट्रोल के साथ फॉर्म का डेमो इमेज व्यू:
डिज़ाइन व्यू में लिस्ट व्यू डेमो फॉर्म।
फ़ॉर्म को डिज़ाइन करना frmListView. फ़ॉन्ट>
-
FrmListView नाम से एक नया फॉर्म बनाएं, और नीचे दिए गए प्रत्येक नियंत्रण के लिए निर्दिष्ट नामों के साथ फॉर्म के विवरण अनुभाग में निम्नलिखित तीन नियंत्रण डालें।
-
प्रपत्र पर एक TreeView नियंत्रण डालें, ActiveX नियंत्रण सूची से, बाईं ओर, नाम को TreeView0 में बदलें . इसकी सामान्य एक्सेस प्रॉपर्टी शीट प्रदर्शित करें और चौड़ाई . बदलें संपत्ति का मूल्य 6.614 सेमी और ऊंचाई से 9.709 सेमी ।
-
ट्री व्यू कंट्रोल के दाईं ओर, ActiveX नियंत्रणों से एक सूची दृश्य नियंत्रण डालें, और उसका नाम बदलकर ListView0 करें . ListView नियंत्रण लगभग 12.462 सेमी . है चौड़ा और 9.709 सेमी ऊंचाई . में , उत्पाद तालिका से डेटा के तीन कॉलम प्रदर्शित करने के लिए पर्याप्त स्थान। दोनों नियंत्रणों को एक दूसरे के पास रखें और शीर्ष किनारों को संरेखित करें।
-
ActiveX नियंत्रण सूची से एक ImageList नियंत्रण सम्मिलित करें, इसे ListView नियंत्रण के दाईं ओर कहीं रखें, और इसके नाम संपत्ति मान को ImageList3 में बदलें .
नोट : फ़ॉन्ट> यदि आप इस विषय पर नए हैं और ActiveX नियंत्रणों के बीच उपरोक्त नियंत्रण नहीं ढूंढ पाए हैं सूची, तो आपको संलग्न करना होगा MSCOMLIB.OCX ( माइक्रोसॉफ्ट विंडोज कॉमन कंट्रोल्स) VBA संपादन विंडो में टूल - -> संदर्भ फाइलों की सूची।मेरा सुझाव है, आप इस पृष्ठ के शीर्ष पर दिए गए पहले लिंक पर जा सकते हैं, माइक्रोसॉफ्ट ट्री व्यू कंट्रोल ट्यूटोरियल मार्गदर्शन के लिए पेज, संबंधित फाइलों को कहां देखना है, और माइक्रोसॉफ्ट विंडोज को कैसे जोड़ना है MSCOMLIB.OCX एक्सेस रेफरेंस लाइब्रेरी में फाइल करें। उसके बाद, आप इन फाइलों को . पर ढूंढ पाएंगे ActiveX Control's सूची।
यदि आप पहले के Tutorial Sessions को पढ़ चुके हैं और ऊपर दिए गए 4th Link से Demo Database डाउनलोड कर चुके हैं, तो उस डेटाबेस को खोलें।
डिज़ाइन दृश्य में ImageList नियंत्रण के साथ प्रपत्र खोलें। प्रपत्र से ImageList नियंत्रण की एक प्रति बनाएं और उसे क्लिपबोर्ड पर रखें। उस डेटाबेस को बंद करें, वर्तमान प्रोजेक्ट डेटाबेस खोलें, और डिज़ाइन व्यू में फॉर्म frmListView खोलें। क्लिपबोर्ड से छविसूची नियंत्रण को प्रपत्र frmListView पर चिपकाएं। ImageList नियंत्रण के नाम को ImageList3 . में बदलें . जिनके पास पहले से लोड की गई छवियों के साथ ImageList नियंत्रण है, निम्न छह चरणों को छोड़ दें और चरण-7 से जारी रखें।
इमेजलिस्ट कंट्रोल में इमेज अपलोड करना।
वैकल्पिक रूप से, यदि आपने ActiveX नियंत्रणों से ImageList नियंत्रण सम्मिलित किया है, तो आप अपने कंप्यूटर से ही कुछ चित्र (4 या 5) अपलोड कर सकते हैं। निम्न कार्य करें:
-
ImageList नियंत्रण पर राइट-क्लिक करें, ImageListCtrl_Object को हाइलाइट करें और गुण . चुनें ।
-
विकल्प चुनें 16 x 16 सामान्य . पर छवि आकार विकल्प टैब।
सावधानी: इमेज अपलोड करने के बाद आप इमेज साइज वैल्यू नहीं बदल सकते। अगर आपको लगता है कि प्रदर्शित होने पर आपको एक अलग आकार की छवियों की आवश्यकता है, तो आपको सभी मौजूदा छवियों को हटाने की जरूरत है और फिर सामान्य टैब पर इच्छित छवि आकार का चयन करें और फिर सभी छवियों को फिर से अपलोड करें।
-
इसके बाद, छवियां . चुनें टैब।
-
चित्र सम्मिलित करें . पर क्लिक करें कमांड बटन और अपनी डिस्क से छवि का चयन करें (अधिकांश छवि प्रकार:bmp, png, JPG, JPEG, और tiff मान्य हैं)। चयनित छवि छवियों . में दिखाई देगी नियंत्रण। चयनित छवि का आकार 16 x 16 पिक्सेल तक कम हो जाएगा और यदि आपने एक बड़ी छवि का चयन किया है तो छवि की गुणवत्ता प्रभावित हो सकती है।
-
छवि का अनुक्रमणिका मान सिस्टम द्वारा दर्ज किया जाता है। कुंजी . में एक उपयुक्त अद्वितीय नाम दर्ज करें नियंत्रण। यदि आप छवि की अनुक्रमणिका संख्या के बजाय, TreeView नोड छवि-पैरामीटर या ListView आइटम के कुंजी-नाम का उपयोग करने की योजना बना रहे हैं तो नाम केस संवेदनशील है।
-
आप इस तरह से आवश्यक संख्या में चित्र अपलोड कर सकते हैं। आप इस इमेजलिस्ट कंट्रोल को अपने अन्य प्रोजेक्ट्स के लिए कॉपी और पेस्ट कर सकते हैं।
-
जब आप आवश्यक छवियों को अपलोड करना समाप्त कर लें तो डायलॉग बॉक्स को बंद कर दें।
-
नाम संपत्ति मान के साथ प्रपत्र पर नियंत्रणों के निचले भाग में एक कमांड बटन डालें:cmdExit और कैप्शन के साथ बाहर निकलें ।
-
आप प्रपत्र frmListView . सहेज सकते हैं अब परिवर्तनों के साथ.
ट्री व्यू के साथ लिस्ट व्यू कंट्रोल को आज़माने के लिए हमें डेमो उद्देश्यों के लिए दो तालिकाओं की आवश्यकता है। मैंने नमूना डेटाबेस Northwind.accdb से ली गई उत्पाद तालिका से दो तालिकाएं बनाई हैं . एक संख्यात्मक प्रकार फ़ील्ड संबंधित है तालिका में जोड़ा जाता है lvश्रेणी.
तालिका में चार नए रिकॉर्ड जोड़े गए। पहले दो नए रिकॉर्ड में उनके BelongsTo . हैं मान के साथ फ़ील्ड 4, यह दर्शाता है कि ये रिकॉर्ड रिकॉर्ड आईडी नंबर 4 के चाइल्ड-नोड्स हैं। इसी तरह, पिछले दो रिकॉर्ड का BelongsTo में मान 10 है। खेत।
आईडी नंबर 4 और 10 के साथ रिकॉर्ड, उत्पाद नाम फ़ील्ड विवरण से पता चलता है कि उनके पास आइटम के कई समूह हैं। मुख्य समूह आइटम के तहत चाइल्ड-नोड रिकॉर्ड के रूप में रखने के लिए श्रेणी समूह के नामों को दो अलग-अलग श्रेणियों में विभाजित किया जा रहा है। श्रेणी के नए समूह रिकॉर्ड आईडी मानों को lvProducts तालिका में उत्पाद आइटम्स के पेरेंटआईडी फ़ील्ड में अपडेट किया गया है, जो नई श्रेणी से संबंधित है। दो अलग-अलग श्रेणियों की वस्तुओं के साथ पहला रिकॉर्ड कुछ अन्य वरीयता विचारों के कारण अछूता छोड़ दिया गया है।
lvश्रेणी तालिका छवि नीचे दी गई है। इसका उपयोग ट्री व्यू नोड्स के लिए, पेरेंट नोड्स के रूप में लिस्ट व्यू कंट्रोल आइटम्स के लिए भी किया जाएगा।
lvउत्पाद तालिका में लगभग 45 रिकॉर्ड हैं। तालिका छवि, कुछ नमूना रिकॉर्ड के साथ, संदर्भ के लिए नीचे दी गई है:
दो टेबल के साथ काम करना।
आगे बढ़ने से पहले हमें दोनों तालिकाओं पर करीब से नज़र डालनी चाहिए और देखें कि ट्री व्यू और लिस्ट व्यू कंट्रोल में दोनों एक दूसरे से कैसे संबंधित हैं। अब तक हमने केवल एक ही टेबल के साथ काम किया है, एक ही टेबल में नोड की, डिस्क्रिप्शन और पेरेंटआईडी फील्ड्स के साथ।
मुझे आशा है कि आप में से जिन्होंने पहले ट्यूटोरियल एपिसोड का पालन किया है, उन्हें एक ही टेबल में समान फील्ड वैल्यू के बीच संबंधों की स्पष्ट समझ है। अब, हम देखेंगे कि कैसे ये दोनों टेबल (lvCategory और lvProducts) दो अलग-अलग नियंत्रणों के लिए एक-दूसरे से संबंधित हैं।
सबसे पहले, lvश्रेणी की जांच करें टेबल। इसमें एक संबंधित है पिछले चार रिकॉर्ड में मूल्यों के साथ क्षेत्र। वे चार रिकॉर्ड lvCategory Nodes के रिकॉर्ड आईडी 4 और 10 के चाइल्ड नोड हैं। ये चार नोड्स, ट्री व्यू कंट्रोल में चाइल्ड नोड्स के रूप में, पेरेंट नोड्स में जाते हैं:डिब्बाबंद फल और सब्जियां और सूखे मेवे और मेवे ट्री व्यू कंट्रोल में ही।
अब, lvProducts लें तालिका और इसमें ParentID . है फ़ील्ड मान। lvश्रेणी . में प्रत्येक श्रेणी आइटम के लिए तालिका, lvProducts . पर एक या अधिक संबंधित उत्पाद आइटम हैं टेबल। ParentID . में नंबर lvProducts . का क्षेत्र तालिका lvश्रेणी . में पैरेंट रिकॉर्ड से संबंधित है टेबल। इसे अलग तरीके से रखने के लिए, ListView नियंत्रण में सूचीबद्ध सभी उत्पाद आइटम, समान ParentID के साथ मान, समान CID . के साथ lvCategory तालिका में किसी विशेष रिकॉर्ड से संबंधित हैं मूल्य।
नोट: उत्पाद तालिका से इन दोनों तालिकाओं को बनाने में काफी समय लग सकता है। यदि आपने अभी तक इस ट्यूटोरियल का अनुसरण किया है, तो आप इस पेज के अंत में दिए गए डाउनलोड लिंक से डेमो डेटाबेस डाउनलोड कर सकते हैं। आयात lvश्रेणी और lvउत्पाद इस प्रोजेक्ट के साथ डेटाबेस से आपके वर्तमान डेटाबेस में तालिकाएँ। जब आप वर्तमान डेटाबेस के साथ इस प्रोजेक्ट को पूरा करते हैं, यदि आप इसके साथ कुछ समस्याओं का सामना करते हैं, तो आप अपने काम को सही करने के लिए डेमो डेटाबेस को संदर्भ बिंदु के रूप में उपयोग कर सकते हैं।
फॉर्म मॉड्यूल VBA कोड।
-
frmListViewखोलें डिज़ाइन व्यू में फॉर्म।
-
प्रपत्र का कक्षा मॉड्यूल प्रदर्शित करें।
-
निम्नलिखित पूर्ण VBA कोड को मॉड्यूल में कॉपी और पेस्ट करें और Ctrl+S दबाएं कोड को सेव करने के लिए।
Option Compare Database Option Explicit Dim tv As MSComctlLib.TreeView Dim lvList As MSComctlLib.ListView Dim imgList As MSComctlLib.ImageList Const Prfx As String = "X" Private Sub Form_Load() Dim db As DAO.Database Dim tbldef As TableDef Set tv = Me.TreeView0.Object tv.Nodes.Clear Set imgList = Me.ImageList3.Object With tv .Font.Size = 9 .Font.Name = "Verdana" .ImageList = imgList 'assign preloaded imagelist control End With Set db = CurrentDb Set tbldef = db.TableDefs("lvProducts") Set lvList = Me.ListView0.Object lvList.ColumnHeaders.Clear lvList.ListItems.Clear lvList.Icons = imgList 'Initialize ListView & Column Headers Property Values With lvList .ColumnHeaderIcons = imgList .Font.Size = 9 .Font.Name = "Verdana" .Font.Bold = False .View = lvwReport .GridLines = True 'ColumnHeaders.Add() Syntax: 'lvList.ColumnHeaders.Add Index, Key, Text, Width, Alignment, Icon 'Alignment: 0 - Left, 1 - Right, 2 - Center .ColumnHeaders.Add 1, , tbldef.Fields(1).Name, 2600, 0, 5 .ColumnHeaders.Add 2, , tbldef.Fields(3).Name, 2600, 0, 5 .ColumnHeaders.Add 3, , tbldef.Fields(4).Name, 1440, 1, 5 End With Set db = Nothing Set tbldef = Nothing LoadTreeView 'Create TreeView Nodes End Sub Private Sub LoadTreeView() Dim Nod As MSComctlLib.Node Dim firstCatID As Long Dim strCategory As String Dim strCatKey As String Dim strProduct As String Dim strPKey As String Dim strBelongsTo As String Dim strSQL As String Dim db As DAO.Database Dim rst As DAO.Recordset 'Initialize treeview nodes tv.Nodes.Clear 'Initialize Listview nodes While lvList.ListItems.Count > 0 lvList.ListItems.Remove (1) Wend strSQL = "SELECT lvCategory.CID, lvCategory.Category, " strSQL = strSQL & "lvcategory.BelongsTo FROM lvCategory ORDER BY lvCategory.CID;" Set db = CurrentDb Set rst = db.OpenRecordset(strSQL, dbOpenSnapshot) If Not rst.BOF And Not rst.EOF Then rst.MoveFirst firstCatID = rst!CID Else Exit Sub End If ' Populate all Records as Rootlevel Nodes Do While Not rst.BOF And Not rst.EOF strCatKey = Prfx & CStr(rst!CID) strCategory = rst!Category Set Nod = tv.Nodes.Add(, , strCatKey, strCategory, 1, 2) Nod.Tag = rst!CID rst.MoveNext Loop 'In the second pass of the the same set of records 'Move Child Nodes under their Parent Nodes rst.MoveFirst Do While Not rst.BOF And Not rst.EOF strBelongsTo = Nz(rst!BelongsTo, "") If Len(strBelongsTo) > 0 Then strCatKey = Prfx & CStr(rst!CID) strBelongsTo = Prfx & strBelongsTo strCategory = rst!Category Set tv.Nodes.Item(strCatKey).Parent = tv.Nodes.Item(strBelongsTo) End If rst.MoveNext Loop rst.Close ' Populate ListView Control with Product details ' of the first Category Item LoadListView firstCatID End Sub Private Sub LoadListView(ByVal CatID) Dim strProduct As String Dim strPKey As String Dim intCount As Integer Dim tmpLItem As MSComctlLib.ListItem Dim db As DAO.Database Dim rst As DAO.Recordset Dim strSQL As String ' Initialize ListView Control While lvList.ListItems.Count > 0 lvList.ListItems.Remove (1) Wend strSQL = "SELECT lvProducts.* FROM lvProducts " strSQL = strSQL & "WHERE (lvProducts.ParentID = " & CatID & ") " strSQL = strSQL & "ORDER BY lvProducts.[Product Name];" 'Open filtered Products List for selected category Set db = CurrentDb Set rst = db.OpenRecordset(strSQL, dbOpenSnapshot) Do While Not rst.BOF And Not rst.EOF intCount = intCount + 1 strProduct = rst![Product Name] strPKey = Prfx & CStr(rst!PID) 'List Item Add() Syntax: 'lvList.ListItems.Add Index,Key,Text,Icon,SmallIcon Set tmpLItem = lvList.ListItems.Add(, strPKey, strProduct, , 3) 'first column lvList.ForeColor = vbBlue 'List second column sub-item Syntax: 'tmpLItem.ListSubItems.Add Column - Index, Key, Text, ReportIcon, ToolTipText tmpLItem.ListSubItems.Add 1, strPKey & CStr(intCount), Nz(rst![Quantity Per Unit], ""), 6 'List third column sub-item tmpLItem.ListSubItems.Add 2, strPKey & CStr(intCount + 1), Format(rst![list Price], "0.00"), 6, "In Local Currency." rst.MoveNext Loop Set db = Nothing Set rst = Nothing If intCount > 0 Then lvList.ListItems(1).Selected = True End Sub Private Sub TreeView0_NodeClick(ByVal Node As Object) Dim Cat_ID As String Cat_ID = Node.Tag LoadListView Cat_ID End Sub Private Sub ListView0_Click() Dim lvKey As String, lvLong As Long Dim Criterion As String lvKey = lvList.SelectedItem.Key lvLong = Val(Mid(lvKey, 2)) DoCmd.OpenForm "ProductDetails", , , , , , lvLong End Sub Private Sub cmdExit_Click() DoCmd.Close End Sub
आइए हम संहिता की समीक्षा करें और यह समझने की कोशिश करें कि वे क्या करते हैं।
वैश्विक घोषणा क्षेत्र में, TreeView ऑब्जेक्ट (tv .) ), लिस्ट व्यू (lvList .) ) और इमेजलिस्ट (imgList ) वस्तु चर घोषित किए जाते हैं। लगातार Prfx वैरिएबल को "X . मान के साथ घोषित किया गया है ” और नोड कुंजी उपसर्ग मान के रूप में उपयोग किया जाता है।
जब frmListView खुला है, Form_Load() घटना प्रक्रिया चलती है। डेटाबेस ऑब्जेक्ट db और TableDef ऑब्जेक्ट वेरिएबल tbldef घोषित कर दिया गया है।
ट्री व्यू0 प्रपत्र पर नियंत्रण वस्तु चर tv. . को सौंपा गया है कथन tv.Nodes.Clear मेमोरी में ट्री व्यू कंट्रोल ऑब्जेक्ट इंस्टेंस को इनिशियलाइज़ करता है।
इसके बाद, imgList ऑब्जेक्ट वैरिएबल को ImageList3 . के साथ इनिशियलाइज़ किया गया है प्रपत्र पर नियंत्रण।
ट्री व्यू कंट्रोल डिस्प्ले फॉन्ट और इमेजलिस्ट प्रॉपर्टीज।
निम्नलिखित कथन ट्री व्यू कंट्रोल का फ़ॉन्ट नाम, फ़ॉन्ट-आकार और इसकी छविसूची सेट करते हैं संपत्ति को imgList . के साथ लोड कर दिया गया है ऑब्जेक्ट, ताकि हम ट्री व्यू नोड इमेज के लिए इमेज की नेम्स या इमेज इंडेक्स नंबर का उपयोग कर सकें।
With tv .Font.Size = 9 .Font.Name = "Verdana" .ImageList = imgList 'assign preloaded imagelist control End With
The ListView कंट्रोल प्रॉपर्टी सेटिंग्स और कॉलम हेडर्स।
उसके बाद, कोड का निम्न खंड ListView नियंत्रण को प्रारंभ करता है और इसके गुण मान निर्दिष्ट करता है।
Set db = CurrentDb Set tbldef = db.TableDefs("lvProducts") Set lvList = Me.ListView0.Object lvList.ColumnHeaders.Clear lvList.ListItems.Clear lvList.Icons = imgList 'Initialize ListView & Column Headers Property Values With lvList .ColumnHeaderIcons = imgList .Font.Size = 9 .Font.Name = "Verdana" .Font.Bold = False .View = lvwReport .GridLines = True 'ColumnHeaders.Add() Syntax: 'lvList.ColumnHeaders.Add Index, Key, Text, Width, Alignment, Icon 'Alignment: 0 - Left, 1 - Right, 2 - Center .ColumnHeaders.Add , , tbldef.Fields(1).Name, 2600, 0, 5 .ColumnHeaders.Add , , tbldef.Fields(3).Name, 2600, 0, 5 .ColumnHeaders.Add , , tbldef.Fields(4).Name, 1440, 1, 5 End With Set db = Nothing Set tbldef = Nothing
डेटाबेस ऑब्जेक्ट tbldef वेरिएबल lvProducts . के साथ असाइन करता है तालिका परिभाषा। ListView कॉलम हेडर . के रूप में उपयोग करने के लिए हमें डेटा फ़ील्ड नामों की आवश्यकता है , उनके संबंधित डेटा मानों के लिए, शीर्ष पर। हैडर टेक्स्ट पैरामीटर मान तालिका फ़ील्ड नाम से लिया जा सकता है।
कॉलम हेडर में एक छवि भी प्रदर्शित की जा सकती है। इसलिए, हमने imgList . असाइन किया है lvList पर आपत्ति करें.ColumnHeaderIcons संपत्ति।
इसके बाद, आवश्यक फ़ॉन्ट, फ़ॉन्ट-आकार, और शैली मान सूची दृश्य नियंत्रण के उनके संबंधित गुणों को असाइन किए गए हैं, यदि डिफ़ॉल्ट मान उपयुक्त नहीं पाए जाते हैं।
दृश्य . को बदलकर ListView को अलग तरह से देखा जा सकता है संपत्ति मूल्य। हमने lvwReport . चुना है (अधिकतम सुविधाओं के साथ मान 3)। आप 0,1 या 2 अन्य मानों को बदल सकते हैं और प्रयोग कर सकते हैं। संपत्ति देखें मान 3 (lvwReport ) कॉलम हेडर के साथ कॉलम में मान प्रदर्शित करता है, छवि चिह्न, और ग्रिड लाइनें।
हमने डेटा के तीन क्षेत्र लिए हैं (उत्पाद का नाम , प्रति इकाई मात्रा, और सूची मूल्य) ListView नियंत्रण में तीन अलग-अलग स्तंभों में प्रदर्शित करने के लिए lvProducts तालिका से।
कॉलम चौड़ाई मान पिक्सेल में है। संरेखण संपत्ति मूल्य श्रेणियां 0 से 2 तक हैं और प्रत्येक मान का अर्थ नीचे दिया गया है:
0 - बाएं संरेखित करें
1 - दायां संरेखित करें
2 - केंद्र संरेखित करें।
कॉलम हैडर जानकारी बनाने के लिए lvList .ColumnHeaders.Add() विधि को पैरामीटर के साथ बुलाया गया है।
जोड़ें () विधि सिंटैक्स:
Object.ColumnHeaders.Add Index, Key, Text, Column Width, Alignment, Icon
कोड खंड में उपरोक्त तीन कथनों के साथ, हमने सभी तीन स्तंभ शीर्षों को फ़ील्ड नामों के साथ जोड़ दिया है:उत्पाद का नाम , प्रति इकाई मात्रा, और सूची मूल्य कॉलम.
हमने किसी भी आइटम को ListView कंट्रोल में जोड़ने से पहले यह कदम उठाया है और वह भी Form_Load() इवेंट प्रक्रिया में, बजाय ListView आइटम्स को पॉप्युलेट करने के।
इसके बाद, LoadTreeView() को कॉल करें ट्री व्यू कंट्रोल नोड्स बनाने के लिए सब-रूटीन। जैसा कि हमने पहले के एपिसोड में चर्चा की है, हमने इस कार्य को दो चरणों वाली प्रक्रिया में विभाजित किया है।
परिवर्तनीय घोषणाओं के बाद, TreeView और ListView नियंत्रण प्रारंभ किए गए हैं।
lvश्रेणी . खोलने के तुरंत बाद रिकॉर्ड सेट, पहले रिकॉर्ड की कुंजी फ़ील्ड (श्रेणी आईडी:CID) मान firstCatID में सहेजा गया है बाद में उपयोग के लिए परिवर्तनीय।
इसके बाद, lvCategory टेबल से सभी रिकॉर्ड्स को शुरू में ट्री व्यू कंट्रोल में रूट-लेवल नोड्स के रूप में जोड़ा जाता है।
रिकॉर्ड के उसी सेट के दूसरे पास में, यह BelongsTo . की जांच करता है फ़ील्ड मान, यदि यह खाली है तो उन नोड्स को रूट-लेवल नोड के रूप में बनाए रखा जाता है, अन्यथा, पेरेंटआईडी फ़ील्ड मान रूट-लेवल नोड की आईडी है। पेरेंटआईडी मान का उपयोग करते हुए वर्तमान नोड को पेरेंट नोड के तहत उसके चाइल्ड नोड के रूप में स्थानांतरित कर दिया गया है।
मैंने पहले के एपिसोड में ट्री व्यू कंट्रोल में नोड्स को पॉप्युलेट करने की दो-चरणीय प्रक्रिया के इस पहलू को समझाया है और पिछले ट्यूटोरियल सत्र में विस्तार से प्रयोगों द्वारा सिद्ध किया गया है।
रिकॉर्डसेट-ऑब्जेक्ट को बंद करने के बाद LoadListView(ByVal CatID) सबरूटीन को बुलाया गया है। प्रथम श्रेणी रिकॉर्ड का CID फ़ील्ड मान firstcatID . में सहेजा गया है चर को फ़ंक्शन के पैरामीटर के रूप में पारित किया गया है।
श्रेणी अद्वितीय CID फ़ील्ड मान चर firstCatID . में पारित हुआ पैरामीटर के रूप में संबंधित उत्पाद रिकॉर्ड्स को फ़िल्टर करने के लिए strSQL स्ट्रिंग में मानदंड के रूप में उपयोग किया गया है।
हमने लिस्ट व्यू कंट्रोल पर प्रदर्शित करने के लिए फ़िल्टर किए गए रिकॉर्ड से केवल चार फ़ील्ड डेटा लिया है। की-फ़ील्ड:PID , उत्पाद का नाम , मात्रा प्रति यूनिट, और सूची मूल्य . PID फ़ील्ड मान का उपयोग कुंजी के रूप में किया गया है और यह प्रदर्शन में दिखाई नहीं देगा।
ColumnHeaders.Add() सभी तीन कॉलम हेडर जोड़ने के लिए विधि को तीन बार बुलाया गया है।
नोट: कथन की जांच करें कि हमने कोई कुंजी पैरामीटर मान प्रदान नहीं किया है, लेकिन सिस्टम द्वारा अनुक्रमणिका मान डाला जाएगा। एक बार लोड हो जाने के बाद हमने कॉलम हेडर के साथ काम करने की योजना नहीं बनाई है। अगर हम करते भी हैं, तो हम कॉलम को इंडेक्स वैल्यू के साथ संबोधित कर सकते हैं। लेकिन, हमें उत्पाद रिकॉर्ड फ़ील्ड मानों को उसी क्रम में लोड करना होगा जिस क्रम में कॉलम हेडर अनुक्रम हैं।
कॉलम में उत्पाद मानों के साथ सूची दृश्य नियंत्रण को पॉप्युलेट करना।
ListView नियंत्रण पर डेटा सूची प्रदर्शित करने के लिए, हमें ListView नियंत्रण में मानों के सभी तीन कॉलम जोड़ने के लिए, तीन अलग-अलग कुंजी मानों के साथ Add() विधियों के दो सेट की आवश्यकता होती है।
पहला कॉलम मान lvList . के साथ जोड़ा जाएगा .सूची आइटम जोड़ें () तरीका। अन्य सभी कॉलम मान lvList . के साथ जोड़े जा सकते हैं .ListSubItems जोड़ें () विधि।
हमने एक काउंटर वेरिएबल बनाया है:intCount, और प्रत्येक Do जबकि पर अपना मान बढ़ाता है। . . lvList में कुंजी-मान को अद्वितीय बनाने के लिए लूप चक्र और उसके वर्तमान मान को कुंजी (PID) मान में जोड़ा जाएगा। ListSubItems.Add() विधि।
पहले कॉलम की ListItems.Add() विधि सिंटैक्स नीचे दिया गया है:
‘lvList.ListItems.Add Index,Key,Text,Icon,SmallIcon
Set tmpLItem = lvList.ListItems.Add(, strPKey, strProduct, , 3)
उपरोक्त कथन ट्री व्यू नोड की ऐड विधि के समान है। tmpLItem ListItem ऑब्जेक्ट . के रूप में घोषित किया गया है और जोड़ा ListItem का संदर्भ रखता है ताकि इसका उपयोग ListSubItems को जोड़ने के लिए किया जा सके।
lvList.ListSubItems.Add() विधि सिंटैक्स थोड़ा अलग है जैसा कि नीचे दिया गया है। दिखाया गया सिंटैक्स दूसरे पैरामीटर मान strPKey और Cstr(intCount + 1) के साथ दूसरी .ListSubItems.Add() विधि के लिए है। . पहली ListSubItems.Add() विधि में कुंजी मान strPKey &Cstr(intCount) के रूप में होगा ।
‘tmpLItem.ListSubItems.Add Index, Key, Text, ReportIcon, ToolTipText
tmpLItem.ListSubItems.Add 2, strPKey & CStr(intCount + 1), Format(rst![List Price], "0.00"), 6, "In Local Currency."
ListSubItem की जोड़ें विधि में ReportIcon है और टूलटिप टेक्स्ट अंतिम दो मापदंडों के रूप में। हमने टूलटिप-टेक्स्ट पैरामीटर मान का उपयोग केवल अंतिम कॉलम के लिए किया है।
एनबी: कॉलम में लोड किए गए मान और उससे संबंधित अन्य सभी सेटिंग्स तभी काम करेंगी जब आप पहले कॉलम को छोड़कर व्यू ऑप्शन -3 (lvwReport) का चयन करेंगे। अन्यथा, उन सभी को अनदेखा कर दिया जाता है।
टूलटिप टेक्स्ट तब प्रदर्शित होता है जब माउस पॉइंटर अंतिम कॉलम पर होवर करता है।
सभी तीन स्तंभों (ListItems &ListSubItems) में जोड़ें () विधि समान रिकॉर्ड PID का उपयोग करती है कुंजी के रूप में मान। चूंकि, एक ही रिकॉर्ड के विभिन्न स्तंभों के लिए अद्वितीय आईडी मान की आवश्यकता होती है क्योंकि ListSubItems के लिए intCount चर मान को एक से बढ़ा दिया गया है और एक स्ट्रिंग में परिवर्तित किया गया है और फिर PID फ़ील्ड मान के साथ जोड़ा गया है।
इस प्रकार चयनित श्रेणी आइटम-संबंधित उत्पाद रिकॉर्ड सभी ListView नियंत्रण में सूचीबद्ध हैं।
पूरा उत्पाद रिकॉर्ड विवरण प्रदर्शित करने के लिए अलग फॉर्म।
चूंकि lvProducts तालिका में अधिक फ़ील्ड और मान हैं, जो हम ListView नियंत्रण पर प्रदर्शित कर सकते हैं, ListView आइटम क्लिक इवेंट एक अलग फॉर्म ProductDetails खोलेगा और पूरा रिकॉर्ड विवरण प्रदर्शित करता है।
चयनित उत्पाद रिकॉर्ड के सभी विवरणों के साथ प्रपत्र की छवि नीचे दी गई है:
The ListView0_Click() इवेंट प्रक्रिया।
Private Sub ListView0_Click() Dim lvKey As String, lvLong As Long Dim Criterion As String lvKey = lvList.SelectedItem.Key lvLong = Val(Mid(lvKey, 2)) DoCmd.OpenForm "ProductDetails", , , , , , lvLong End Sub
ListView0_Click() ईवेंट उत्पाद की कुंजी- . को निकालता है मान लें और इसे ओपन आर्ग्युमेंट (OpenArgs) के रूप में फॉर्म में पास करें।
उत्पाद विवरण प्रपत्र।
Form_Open() ईवेंट प्रक्रिया में, OpenArgs स्रोत रिकॉर्ड को फ़िल्टर करने और उन्हें प्रपत्र पर प्रदर्शित करने के लिए फ़िल्टर मानदंड बनाने के लिए मान का उपयोग किया गया है।
ProductDetails फॉर्म मॉड्यूल कोड लिस्टिंग:
Option Compare Database Option Explicit Private Sub cmdClose_Click() DoCmd.Close End Sub Private Sub Form_Open(Cancel As Integer) Dim lngID As Long lngID = Nz(Me.OpenArgs, 0) If lngID > 0 Then Me.Filter = "id = " & lngID Me.FilterOn = True End If End Sub Private Sub Form_Unload(Cancel As Integer) With Me .Filter = "" .FilterOn = False End With End Sub
उत्पाद विवरण प्रपत्र का स्रोत डेटा फ़िल्टर किए गए रिकॉर्ड से आता है, जो OpenArgs के माध्यम से प्रपत्र को दिए गए PID (उत्पाद आईडी) कोड के आधार पर होता है। मूल उत्पाद तालिका को NorthWind.accdb डेटाबेस से डाउनलोड किया गया और उसका नाम बदलकर ProductNew कर दिया गया।
आशा है कि आपको ListView Control Project करने में मज़ा आया होगा। ListView नियंत्रण के साथ आने के लिए और अधिक।
नीचे दिए गए लिंक से डेमो डेटाबेस डाउनलोड करें, और हैप्पी लिस्ट व्यूइंग।
क्रिसमस की शुभकामनाएं और नया साल मुबारक। फ़ॉन्ट>
<बी>डेमो डेटाबेस डाउनलोड करें।
- एक्सेल का राउंडडाउन फ़ंक्शन
- माउसमूव इवेंट से कॉल फंक्शन
- दिनांक2पाठ्य और पाठ2दिनांक समारोह
- विथइवेंट्स एमएस-एक्सेस क्लास मॉड्यूल ट्यूटोरियल
- इवेंट के साथ और अपने खुद के इवेंट को परिभाषित करना
- घटनाओं के साथ बटन कॉम्बो सूची टेक्स्टबॉक्स टैब