Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-10-2008, 14:11   #1
R1((ky
Senior Member
 
L'Avatar di R1((ky
 
Iscritto dal: Apr 2000
Città: Piacenza d'Adige (PD)
Messaggi: 651
[C#] Treeview e ListView collegata

Salve a tutti, mi sto cimentando con il C#, creando una piccola applicazione che crea un albero di categorie da un database (usando l'ID della categoria di livello superiore), poi una volta selezionato il nodo dell'albero, dovrebbe comparire nella ListView la lista degli articoli presenti in quella categoria.

Qualcosa sono riuscito a fare, solo che non riesco a trovare il metodo per filtrare la query degli articoli della ListView in base alla categoria selezionata nel treeview.

Il codice è il seguente:

Codice:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;

namespace Treeview
{
    public partial class Articoli : Form
    {
        public Articoli()
        {
            InitializeComponent();
            string connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Datapref.mdb";
            int? ParentUID = null;
            System.Collections.ArrayList tnodes = new System.Collections.ArrayList();
            OleDbConnection conn = new OleDbConnection(connString);
            DataSet ds = new DataSet();
            conn.Open();
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM TblArtCat", conn);
            adapter.Fill(ds);
            conn.Close();

            DataTable dtbParent = new DataTable();
            dtbParent = ds.Tables[0];

            foreach (DataRow drowParent in dtbParent.Rows)
            {
                if (ParentUID == null)
                {
                    ParentUID = 0;
                    TreeNode node = new TreeNode();
                    node.Text = drowParent["ArtCatDeb"].ToString();
                    node.Tag = (int)drowParent["ArtCatKey"];
                    TreeCat.Nodes.Add(node);
                    tnodes.Add(node);
                }
                else
                {
                    ParentUID = (int)drowParent["ArtCatLnk"];


                    //Se è il primo nodo
                    if (ParentUID == 0)
                    {
                        TreeNode node = new TreeNode();
                        node.Text = drowParent["ArtCatDeb"].ToString();
                        node.Tag = (int)drowParent["ArtCatKey"];
                        TreeCat.Nodes.Add(node);
                        tnodes.Add(node);
                    }
                    else
                    {
                        for (int i = 0; i < tnodes.Count; i++)
                        {
                            if ((int)((TreeNode)tnodes[i]).Tag == ParentUID)
                            {
                                TreeNode node = new TreeNode();
                                node.Text = drowParent["ArtCatDeb"].ToString();
                                node.Tag = (int)drowParent["ArtCatKey"];
                                tnodes.Add(node);
                                ((TreeNode)tnodes[i]).Nodes.Add(node);
                                break;
                            }
                            //Fine albero

                        }
                    }
                }
            }
        }

        private void TreeCat_AfterSelect(object sender, TreeViewEventArgs e)
        {
            string connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Datapref.mdb";
            OleDbConnection conn = new OleDbConnection(connString);
            DataSet DGrid = new DataSet();
            
            conn.Open();
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT ArtKey, ArtDeb FROM TblArt WHERE TblArt.ArtCatKey = 29" , conn);
            adapter.Fill(DGrid);
            DataTable dtable = new DataTable();
            dtable = DGrid.Tables[0];

            // Svuota la Listview
            ArtGrid.Items.Clear();
            
            for (int i = 0; i < dtable.Rows.Count; i++)
            {
                DataRow drow = dtable.Rows[i];

                // Definisce Item e SubItems
                ListViewItem lvi = new ListViewItem(drow["ArtKey"].ToString());
                lvi.SubItems.Add(drow["ArtDeb"].ToString());
                // Aggiunge i dati alla Listview
                ArtGrid.Items.Add(lvi);
            }
            conn.Close();
        }

        private void Chiudi_Click(object sender, EventArgs e)
        {
            this.Close();

        }


    }


}
Ora nella query degli articoli c'è una categora fissa, come fare per leggere l'Id (ArtCatKey) dal nodo selezionato?

Grazie a chi mi aiuterà!
R1((ky è offline   Rispondi citando il messaggio o parte di esso
Old 22-10-2008, 15:39   #2
R1((ky
Senior Member
 
L'Avatar di R1((ky
 
Iscritto dal: Apr 2000
Città: Piacenza d'Adige (PD)
Messaggi: 651
Grazie lo stesso, ho risolto da solo usando il Tag del Node dentro la query.

Per l'utilità di tutti includo il codice corretto:

Codice:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;

namespace Treeview
{
    public partial class Articoli : Form
    {
        public Articoli()
        {
            InitializeComponent();
            string connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Datapref.mdb";
            int? ParentUID = null;
            System.Collections.ArrayList tnodes = new System.Collections.ArrayList();
            OleDbConnection conn = new OleDbConnection(connString);
            DataSet ds = new DataSet();
            conn.Open();
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM TblArtCat", conn);
            adapter.Fill(ds);
            conn.Close();

            DataTable dtbParent = new DataTable();
            dtbParent = ds.Tables[0];

            foreach (DataRow drowParent in dtbParent.Rows)
            {
                if (ParentUID == null)
                {
                    ParentUID = 0;
                    TreeNode node = new TreeNode();
                    node.Text = drowParent["ArtCatDeb"].ToString();
                    node.Tag = (int)drowParent["ArtCatKey"];
                    TreeCat.Nodes.Add(node);
                    tnodes.Add(node);
                }
                else
                {
                    ParentUID = (int)drowParent["ArtCatLnk"];


                    //Se è il primo nodo
                    if (ParentUID == 0)
                    {
                        TreeNode node = new TreeNode();
                        node.Text = drowParent["ArtCatDeb"].ToString();
                        node.Tag = (int)drowParent["ArtCatKey"];
                        TreeCat.Nodes.Add(node);
                        tnodes.Add(node);
                    }
                    else
                    {
                        for (int i = 0; i < tnodes.Count; i++)
                        {
                            if ((int)((TreeNode)tnodes[i]).Tag == ParentUID)
                            {
                                TreeNode node = new TreeNode();
                                node.Text = drowParent["ArtCatDeb"].ToString();
                                node.Tag = (int)drowParent["ArtCatKey"];

                                tnodes.Add(node);
                                ((TreeNode)tnodes[i]).Nodes.Add(node);
                                break;
                            }
                            //Fine albero

                        }
                    }
                }
            }
        }

        private void TreeCat_AfterSelect(object sender, TreeViewEventArgs e)
        {
            string connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Datapref.mdb";
            OleDbConnection conn = new OleDbConnection(connString);
            DataSet DGrid = new DataSet();
            conn.Open();
            string s2 = TreeCat.SelectedNode.Tag.ToString();
            string s1 = "SELECT ArtKey, ArtDeb FROM TblArt WHERE TblArt.ArtCatKey =";
            s1 += s2;
            OleDbDataAdapter adapter = new OleDbDataAdapter(s1, conn);
            adapter.Fill(DGrid);
            DataTable dtable = new DataTable();
            dtable = DGrid.Tables[0];

            // Svuota la Listview
            ArtGrid.Items.Clear();
            
            for (int i = 0; i < dtable.Rows.Count; i++)
            {
                DataRow drow = dtable.Rows[i];

                // Definisce Item e SubItems
                ListViewItem lvi = new ListViewItem(drow["ArtKey"].ToString());
                lvi.SubItems.Add(drow["ArtDeb"].ToString());
                // Aggiunge i dati alla Listview
                ArtGrid.Items.Add(lvi);
            }
            conn.Close();
        }

        private void Chiudi_Click(object sender, EventArgs e)
        {
            this.Close();

        }

     


        


       
    }


}
R1((ky è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
Robot aspirapolvere per tutte le tasche:...
Accedere alle mail di un lavoratore lice...
Amazon Haul scatenato: migliaia di prodo...
Amazon Seconda Mano rilancia: sconto ext...
Super prezzo Amazon per ECOVACS DEEBOT T...
NVIDIA Shield TV: dieci anni di aggiorna...
Le 10 offerte migliori su Amazon oggi, c...
Autostrade che 'pensano': l'AI arriva su...
AMD alza l'asticella: Zen 6 è la ...
Il satellite spia russo Olymp-1 si &egra...
Rocket Lab prosegue l'assemblaggio del n...
Il Wet Dress Rehearsal della missione Ar...
31,4 Tbps: Aisuru sfonda il suo stesso r...
Giocattoli AI, una falla espone oltre 50...
OPPO Reno15 in viaggio con Gaia Gozzi: i...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 10:57.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v