Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Realizzato da Lenovo e installato presso il Cineca di Casalecchio di Reno, Pitagora offre circa 44 PFlop/s di potenza di calcolo ed è dedicato alla simulazione della fisica del plasma e allo studio dei materiali avanzati per la fusione, integrandosi nell’ecosistema del Tecnopolo di Bologna come infrastruttura strategica finanziata da EUROfusion e gestita in collaborazione con ENEA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Rullo di lavaggio dei pavimenti abbinato a un potente motore da 28.000 Pa e a bracci esterni che si estendono: queste, e molte altre, le caratteristiche tecniche di Z60 Ultra Roller Complete, l'ultimo robot di Mova che pulisce secondo le nostre preferenze oppure lasciando far tutto alla ricca logica di intelligenza artificiale integrata
Renault Twingo E-Tech Electric: che prezzo!
Renault Twingo E-Tech Electric: che prezzo!
Renault annuncia la nuova vettura compatta del segmento A, che strizza l'occhio alla tradizione del modello abbinandovi una motorizzazione completamente elettrica e caratteristiche ideali per i tragitti urbani. Renault Twingo E-Tech Electric punta su abitabilità, per una lunghezza di meno di 3,8 metri, abbinata a un prezzo di lancio senza incentivi di 20.000€
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-02-2011, 21: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, 16: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, 15: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, 15: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


Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare Cineca inaugura Pitagora, il supercomputer Lenov...
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA Mova Z60 Ultra Roller Complete: pulisce bene gra...
Renault Twingo E-Tech Electric: che prezzo! Renault Twingo E-Tech Electric: che prezzo!
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
Da Intel ad AMD, il grande salto di Kulk...
Velocità 12 volte superiore a que...
Una piccola Morte Nera è gi&agrav...
Sei frodi che minacciano gli utenti nel ...
BioShock 4: Take-Two rassicura sullo svi...
Tesla, Musk promette FSD 'quasi pronto' ...
BioWare conferma: il nuovo Mass Effect &...
5 robot aspirapolvere di fascia alta in ...
Xiaomi Redmi Note 14 5G a 179€ è ...
Veri affari con gli sconti de 15% Amazon...
Tutti gli iPhone 16 128GB a 699€, 16e a ...
Take-Two ammette: vendite di Borderlands...
Tutti i Macbook Air e Pro con chip M4 ch...
GeForce RTX 50 SUPER: non cancellate, ma...
Warner Bros. riporterà al cinema ...
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: 15:46.


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