Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
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


DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
TIM, rincari da luglio: come evitare l'a...
WWDC 26: Il Digital Markets Act dell'Uni...
WWDC 26: Apple Intelligence rivoluziona ...
Siri AI arriva alla WWDC 2026: nuove cap...
Alla WWDC 2026 arriva la nuova architett...
Tra schede madri, schede video e IA le n...
Nintendo, multa da 35 milioni di euro in...
L'amministrazione Trump valuta una parte...
WWDC 26: Apple rinnova il controllo pare...
Apple al WWDC 26 presenta iOS 27: Liquid...
Xbox, alla fine, dà ragione a Pla...
Minecraft Dungeons 2: Microsoft ha annun...
Synology al Computex 2026: nuova generaz...
Quobly raccoglie 115 milioni di euro per...
BYD batte sul tempo Tesla Roadster: avvi...
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: 03:31.


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