Torna indietro   Hardware Upgrade Forum > Software > Programmazione

I nuovi notebook Acer al debutto al Computex 2025
I nuovi notebook Acer al debutto al Computex 2025
Al Computex 2025 di Taipei Acer mostra una completa gamma di soluzioni notebook delle famiglie Swift, Aspire, Predator e Nitro pensati per gli utenti consumer oltre che per coloro che ricercano elevata potenza di elaborazione, per lavorare o per giocare. In base al modello troviamo piattaforme Intel, AMD oppure Qualcomm anche in abbinamento alle nuove GPU NVIDIA GeForce RTX 5000
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom
All'evento globale di Nutanix l'azienda ha presentato una serie di novità mirate a ridurre la dipendenza dalle soluzioni di VMware/Broadcom. Arriva Cloud Native AOS, soluzione che non richiede di appoggiarsi ad hypervisor. Novità per Nutanix Enterprise AI. Potenziata la collaborazione con Pure Storage per uno storage dedicato ad altissime prestazioni
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo!
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo!
HUAWEI è capace di sorprendere ancora e quest’anno lo fa con questo nuovo smartwatch WATCH FIT 4 Pro che coniuga un design elegante e moderno con funzionalità di prim’ordine. Ultra-sottile con display AMOLED, funzionalità avanzate per sport e salute, e un'autonomia fino a 10 giorni.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-02-2011, 20:19   #1
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
[VB.NET] Problema con libreria ZedGraph

Buonasera,
sto sviluppando un gestionale per bilancio familiare.
Nel database ho una tabella che si chiama gruppoentrate(id,gruppo) e un'altra che si chiama entrate(id,data,importo,descrizione,saldata,idgruppo) dove tra le due c'è una relazione 1 a molti tra gruppoentrate.id e entrate.idgruppo.

Posto il codice per creare il grafico:
Codice:
Private Sub CreaGrafico()
        Dim myPane As GraphPane = zgcGrafico.GraphPane
        Dim titolo, asseX As String
        Dim sql, saldate, nomesaldate As String
        Dim list = New PointPairList()

        
        titolo = "Statistiche per Gruppi nell'anno " & dtpAnno.Value.Year & " , Gruppo: Tutti"
        asseX = "Gruppi"

        ' Set Titolo e Nome Assi
        myPane.Title.Text = titolo
        myPane.XAxis.Title.Text = "Mesi"
        myPane.YAxis.Title.Text = "Valore (€)"

        'Query
        sql = "SELECT idgruppo,SUM(importo) AS sommai " & _
                      "FROM entrate " & _
                      "WHERE Year(data)=" & dtpAnno.Value.Year & " ' GROUP BY idgruppo"

                'esegue la query
                Dim cmd As New OleDbCommand(sql, Cn)

                Dim dr As OleDbDataReader

                Try
                'inserisce il risultato nel datareader
                dr = cmd.ExecuteReader
                'legge il datareader
                While dr.Read()
                    Dim importo As Double
                    If dr.IsDBNull(1) = False Then
                        importo = dr.Item("sommai")
                    Else
                        importo = 0
                    End If

                    list.Add(dr.Item("id"), importo)
                End While

                dr.Close()
                Catch ex As Exception
                    MessageBox.Show("Errore: " & ex.Message.ToString, "Errore..", MessageBoxButtons.OK, MessageBoxIcon.Exclamation)
                    Exit Sub
                End Try
        End Select

        ' Genero la barra con la leggenda
        Dim myBar As BarItem = myPane.AddBar("Entrate (Saldate: Tutte)", list, Color.Blue)

        ' Riempio lo sfondo degli assi con un colore gradiente
        myPane.Chart.Fill = New Fill(Color.White, Color.LightGoldenrodYellow, 45.0F)


        myPane.Fill = New Fill(Color.White, Color.FromArgb(220, 220, 255), 45.0F)

        myPane.XAxis.Scale.FontSpec.Angle = 90

        myPane.XAxis.MajorTic.IsBetweenLabels = True

        myPane.YAxis.Scale.Format = "C"

        zgcGrafico.IsShowPointValues = True

        ' Calculate the Axis Scale Ranges
        zgcGrafico.AxisChange()
    End Sub
Il risultato è questo:
Spoiler:




e fin qui tutto ok adesso al posto dell'idgruppo sull'assex vorrei visualizzare il nome del gruppo dovrei cambiare la query in questo modo:
Codice:
'Query
        sql = "SELECT gruppo,SUM(importo) AS sommai " & _
                      "FROM gruppoentrate INNER JOIN entrate ON gruppoentrate.id = entrate.idgruppo " & _
                      "WHERE Year(data)=" & dtpAnno.Value.Year & " ' GROUP BY gruppo"

                'esegue la query
                Dim cmd As New OleDbCommand(sql, Cn)

                Dim dr As OleDbDataReader

                Try
                'inserisce il risultato nel datareader
                dr = cmd.ExecuteReader
                'legge il datareader
                While dr.Read()
                    Dim importo As Double
                    If dr.IsDBNull(1) = False Then
                        importo = dr.Item("sommai")
                    Else
                        importo = 0
                    End If

                    list.Add(dr.Item("gruppo"), importo)
                End While

                dr.Close()

 Dim myBar As BarItem = myPane.AddBar("Entrate (Saldate: Tutte)", list, Color.Blue)
Adesso il problema è sulla riga in rosso perchè la lista (PointPairList() di ZedGraph) accetta solo campo double, lo stesso vale per la stringa il blu dove va la lista li si accetta solo un campo double.

Come posso fare per visualizzare i nomi del gruppo?

Grazie in anticipo a tutti
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2011, 15:32   #2
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
up
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2011, 14:03   #3
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
up
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2011, 14:32   #4
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
Sono riuscito a risolvere il problema.
Lo posto così se può servire a qualcun'altro che ha lo stesso problema:

Ho modificato la query dove prima utilizzavo un pointparlist() adesso invece utilizzo un datasourcepointlist() dove lo chiamp dspl:
Codice:
sql = "SELECT gruppo,SUM(importo) AS sommai " & _
                      "FROM gruppoentrate INNER JOIN entrate ON gruppoentrate.id = entrate.idgruppo " & _
                      "WHERE Year(data)=" & dtpAnno.Value.Year & " AND Saldata<>'" & saldate & "' GROUP BY gruppo"

                Dim DS As New DataSet 'Variabile per DataSet
                Dim DA As OleDb.OleDbDataAdapter 'crea il dataadapter

                Try
                    'Dataset
                    DS = New DataSet("entrate")
                    'DataAdapter
                    DA = New OleDb.OleDbDataAdapter(sql, Cn)
                    DA.Fill(DS, "entrate")

                    dspl.DataSource = DS.Tables(0)

                    dspl.XDataMember = "gruppo"
                    dspl.YDataMember = "sommai"
                Catch ex As Exception
                    MessageBox.Show("Errore: " & ex.Message.ToString, "Errore..", MessageBoxButtons.OK, MessageBoxIcon.Exclamation)
                    Exit Sub
                End Try
poi prima di associare la query alla barra (dove dgwriepiloco è un datagridview che contiene il nome del gruppo delle entrare si può utilizzare anche una query):

Codice:
myPane.XAxis.Scale.FontSpec.Angle = 90

                Dim nomegruppo(dgwRiepilogo.Rows.Count - 1) As String

                For i = 0 To dgwRiepilogo.Rows.Count - 1
                    nomegruppo(i) = dgwRiepilogo.Item(0, i).Value
                Next

                myPane.XAxis.Type = AxisType.Text
                myPane.XAxis.Scale.TextLabels = nomegruppo
e infine associare la query alla barra:

Codice:
Dim myCurve As BarItem = myPane.AddBar("Entrate (Saldate: " & nomesaldate & ")", dspl, Color.Blue)
jackk87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


I nuovi notebook Acer al debutto al Computex 2025 I nuovi notebook Acer al debutto al Computex 202...
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom Nutanix .NEXT: così l'azienda vuole aiuta...
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo! HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha...
Test NIU RQi Sport, vi spieghiamo perché una moto così è perfetta Test NIU RQi Sport, vi spieghiamo perché ...
Start Campus: il datacenter raffreddato dal mare Start Campus: il datacenter raffreddato dal mare
La capsula W-3 di Varda Space è r...
La Cina sta realizzando la costellazione...
Il rover NASA Perseverance ha fotografat...
Apple Vision Pro, i pentiti dell'acquist...
Tesla: ecco FSD (Supervisionato) alle pr...
L'attesissimo "The Odyssey" di...
PlayStation 5 PRO torna su Amazon: la co...
Dissipatori AIO con schermi sempre pi&ug...
Samsung Galaxy S25 e S25 Ultra in offert...
Apple iPhone 16 Pro Max scende a 1.199€ ...
Altilium produce le prime celle EV su sc...
Grok e l'insistenza sul "genocidio ...
Marathon: Bungie ammette l'uso non autor...
Rockstar: il rinvio di GTA VI è u...
OPPO A5, A5 5G e A5x: OPPO lancia a sor...
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: 20:47.


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