Hola,
Hace poco Microsoft publicó “a cool new ASP.NET server control – <asp:chart />”. Solo entrar en el artículo vi los gráficos generados tan geniales que no tuve mas remedio que probarlos en una aplicación (simple) de ejemplo.
Junto con los assemblies necesarios se puede descargar la documentación y el código fuente del site de ejemplo que viene en la documentación…great!!!
El objetivo de la mini-prueba será realizar un gráfico a partir de un dataset. En el ejemplo será un dataset con información de líneas de código añadidas por usuario.
Insertamos el control chart dentro del .aspx.
|
<asp:Chart ID="chtLineas" runat="server" Palette="BrightPastel" BackColor="#F3DFC1" Width="412px" Height="296px" BorderDashStyle="Solid" BackGradientStyle="TopBottom" BorderWidth="2" BorderColor="181, 64, 1"></asp:Chart> |
Y realizamos la llamada a un servicio que nos devuelve un dataset utilizándolo como datasource del control chart.
|
//LLamada a un servicio que devuelve un dataset con información de lineas añadidas de código por persona.La tabla tiene la columna Cantidad(int) y Nombre (string). SvcPrueba svc = new SvcPrueba(); LineasPorPersonaDataset ds = svc.GetLineasCodigoPorFecha(DateTime.Now.ToShortDateString()); //Se creará una serie en el chart para mostrar un grafico X/Y Nombre/Cantidad chtLineas.Titles[0].Text = "Líneas de código añadidas";
//Se define las columnas y filas del gráfico de la serie que se está creando. Series serieLinea = new Series("SerieLineas"); serieLinea.YValueMembers = "Lineas"; serieLinea.XValueMember = "Nombre"; serieLinea.ChartType = SeriesChartType.Bar; chtLineas.Series.Add(serieLinea); //Pasamos la tabla tLineas al datasource del control chart chtLineas.DataSource = ds.tLineas; chtLineas.DataBind(); |
A partir de aquí, con un poco de imaginación (y tiempo) se abre un mundillo de gráficos que tanto gustan a la gente (en contra de los megadatagrids con cientos de números jejeje). (Imagen cogida del site de ejemplo del control Chart)
Saludos, Garrin.
fantastico, gracias por la informacion!