c#图标、显示图表、图形、json echarts实例 数据封装【c#】
page:
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="ViewxxxxChartsInfo.ascx.cs" Inherits="DotNetNuke.Modules.HRAddUser.ViewxxxxChartsInfo" %>
<style type="text/css">
.GridHead th {
text-align: center;
}
</style>
<asp:Panel ID="panMain" runat="server">
<table style="border: 1px solid #e1e0e0">
<tr>
<td>
<asp:Label ID="Label3" runat="server" Text="查询范围:"></asp:Label>
<asp:DropDownList ID="ddlDateArray" runat="server">
<asp:ListItem Selected="True" Text="选择一" Value="选择一"></asp:ListItem>
<asp:ListItem Text="选择二" Value="选择二"></asp:ListItem>
<asp:ListItem Text="全部" Value="全部"></asp:ListItem>
</asp:DropDownList>
<asp:Label ID="Label4" runat="server" Text="xxxx名称:"></asp:Label>
<asp:TextBox ID="tbxInfoxxxxxName" runat="server"></asp:TextBox>
<asp:Button ID="btnselect" runat="server" Text="查询" OnClick="btnselect_Click" ControlStyle-BackColor="#0ea915" ControlStyle-ForeColor="White" />
</td>
</tr> <tr>
<td> <div id="container" style="height: 600px; width: 1000px"></div>
</td>
</tr>
<asp:Label ID="Type1" runat="server" Style="display: none;"></asp:Label>
<asp:Label ID="Type2" runat="server" Style="display: none;"></asp:Label>
<asp:Label ID="Type3" runat="server" Style="display: none;"></asp:Label>
<asp:Label ID="Type4" runat="server" Style="display: none;"></asp:Label>
<asp:Label ID="Type5" runat="server" Style="display: none;"></asp:Label>
</table>
<script type="text/javascript" src="http://www.shicishu.com/down/echarts.min.js"></script>
<script type="text/javascript" src="http://www.shicishu.com/down/echarts-gl.min.js"></script>
<script type="text/javascript">
var span1 = document.getElementById('<%=Type1.ClientID%>').innerHTML;
var sp1 = JSON.parse(span1);
var span2 = document.getElementById('<%=Type2.ClientID%>').innerHTML;
var sp2 = JSON.parse(span2);
var span3 = document.getElementById('<%=Type3.ClientID%>').innerHTML;
var sp3 = JSON.parse(span3);
var span4 = document.getElementById('<%=Type4.ClientID%>').innerHTML;
var sp4 = JSON.parse(span4);
var span5 = document.getElementById('<%=Type5.ClientID%>').innerHTML;
var sp5 = JSON.parse(span5); let maxValue2 = Math.max.apply(null, sp2);
let maxValue3 = Math.max.apply(null, sp3);
let maxValue4 = Math.max.apply(null, sp4);
let maxValue5 = Math.max.apply(null, sp5);
var arr = [maxValue2, maxValue3, maxValue4,maxValue5];
let maxval = Math.max.apply(null, arr); var dom = document.getElementById("container");
var myChart = echarts.init(dom);
var app = {};
option = null;
option = {
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'cross',
crossStyle: {
color: '#999'
}
}
},
toolbox: {
feature: {
dataView: { show: true, readOnly: false },
magicType: { show: true, type: ['line', 'bar'] },
restore: { show: true },
saveAsImage: { show: true }
}
},
legend: {
data: ['营业收入', '应缴管理费', '实缴管理费','尚欠管理费']
},
xAxis: [
{
type: 'category',
data: sp1,
axisPointer: {
type: 'shadow'
}
}
],
yAxis: [
{
type: 'value',
name: '金额(元)',
min: 0,
max: maxval,
interval: maxval/10,
axisLabel: {
formatter: '{value}'
}
} ],
series: [
{
name: '营业收入',
type: 'bar',
data: sp2
},
{
name: '应缴管理费',
type: 'bar',
data: sp3
},
{
name: '实缴管理费',
type: 'bar',
data: sp4
},
{
name: '尚欠管理费',
type: 'bar',
data: sp5
}
]
}; if (option && typeof option === "object") {
myChart.setOption(option, true);
}
</script>
</asp:Panel>
controller:
using System;
using System.Data;
using System.Web.UI.WebControls;
using DotNetNuke.Modules.ControllerData;
using DotNetNuke.Security;
using DotNetNuke.Services.Localization; namespace DotNetNuke.Modules.ControllerData
{
public partial class ViewxxxxChartsInfo : DotNetNuke.Entities.Modules.PortalModuleBase, DotNetNuke.Entities.Modules.IActionable
{
private ControllerData CD = new ControllerData();
private DataTable dtTosxxxInfo = new DataTable(); protected void Page_Load(object sender, EventArgs e)
{ FillDG(); if (!IsPostBack)
{
FillUI();
}
} private void FillDG()
{ string swhere = " where xxxxName like '%" + tbxInfoxxxxxName.Text + "%' ";
bool OnlyExpire;
if (ddlDateArray.Text == "全部")
OnlyExpire = false;
else
OnlyExpire = true; dtTosxxxInfo = CD.GetTosxxxxChartsInfo(swhere, ddlDateArray.Text);
} private void FillUI()
{
Type1.Text = Convert.ToString(dtTosxxxInfo.Rows[0]["jsons"]);
Type2.Text = Convert.ToString(dtTosxxxInfo.Rows[1]["jsons"]);
Type3.Text = Convert.ToString(dtTosxxxInfo.Rows[2]["jsons"]);
Type4.Text = Convert.ToString(dtTosxxxInfo.Rows[3]["jsons"]);
Type5.Text = Convert.ToString(dtTosxxxInfo.Rows[4]["jsons"]);
}
//页面响应移动代码
#region IActionable 成员 DotNetNuke.Entities.Modules.Actions.ModuleActionCollection DotNetNuke.Entities.Modules.IActionable.ModuleActions
{
get
{
Entities.Modules.Actions.ModuleActionCollection Actions = new
Entities.Modules.Actions.ModuleActionCollection();
Actions.Add(GetNextActionID(),
Localization.GetString(Entities.Modules.Actions.ModuleActionType.AddContent,
LocalResourceFile), Entities.Modules.Actions.ModuleActionType.AddContent, "", "",
EditUrl(), false, SecurityAccessLevel.Edit, true, false);
return Actions;
}
} #endregion
protected void btnselect_Click(object sender, EventArgs e)
{
FillDG();
FillUI();
}
}
}
data:
/// <summary>
/// 获取xxxxxx收入、应缴、实缴、尚欠金额统计json.
/// </summary>
/// <param name="where"></param>
/// <param name="DateA"></param>
/// <returns></returns>
public DataTable GetTosxxxChartsInfo(string where, string DateA)
{
DataTable dtchart = new DataTable();
dtchart.Columns.Add("jsons"); List<string> list1 = new List<string>();
List<decimal> list2 = new List<decimal>();
List<decimal> list3 = new List<decimal>();
List<decimal> list4 = new List<decimal>();
List<decimal> list5 = new List<decimal>(); DataTable dtbc = GetTosxxxViewInfo(where, DateA);//数据层-统计计算封装表
if (dtbc.Rows.Count > 0)
{
string Tosxxxname = "";
decimal Total2 = 0, Total3 = 0, Total4 = 0, Total5 = 0;
for (int t = 0; t < dtbc.Rows.Count; t++)
{
Tosxxxname = Convert.ToString(dtbc.Rows[t]["OAxxxxName"]);
Total2 = Convert.ToDecimal(dtbc.Rows[t]["xxxxIngahter"]);
Total3 = Convert.ToDecimal(dtbc.Rows[t]["xxxxAdminFee"]);
Total4 = Convert.ToDecimal(dtbc.Rows[t]["xxxAdminFee"]);
Total5 = Convert.ToDecimal(dtbc.Rows[t]["xxxxAdminFee"]);
list1.Add(Tosxxxname);
list2.Add(Total2);
list3.Add(Total3);
list4.Add(Total4);
list5.Add(Total5);
}
}
dtchart.Rows.Add(new object[] { Newtonsoft.Json.JsonConvert.SerializeObject(list1) });
dtchart.Rows.Add(new object[] { Newtonsoft.Json.JsonConvert.SerializeObject(list2) });
dtchart.Rows.Add(new object[] { Newtonsoft.Json.JsonConvert.SerializeObject(list3) });
dtchart.Rows.Add(new object[] { Newtonsoft.Json.JsonConvert.SerializeObject(list4) });
dtchart.Rows.Add(new object[] { Newtonsoft.Json.JsonConvert.SerializeObject(list5) });
return dtchart;
}
c#图标、显示图表、图形、json echarts实例 数据封装【c#】的更多相关文章
- JFreeChart与AJAX+JSON+ECharts两种处理方式生成热词统计可视化图表
本篇的思想:对HDFS获取的数据进行两种不同的可视化图表处理方式.第一种JFreeChar可视化处理生成图片文件查看.第二种AJAX+JSON+ECharts实现可视化图表,并呈现于浏览器上. 对 ...
- 在OAF页面中集成ECharts以及highcharts用于显示图表
历史博文中有讲解在请求中输出基础图表的方式,见地址:EBS 请求输出Html报表集成Echarts 本文讲述在OAF中集成这两类图表. 集成的基本思路:在OAF页面中加入一个rawText组件,在ra ...
- 【转】 C# ListView实例:文件图标显示
[转] C# ListView实例:文件图标显示 说明:本例将目录中的文件显示在窗体的ListView控件中,并定义了多种视图浏览.通过调用Win32库函数实现图标数据的提取. 主程序: 大图标: 列 ...
- 三大图表库:ECharts 、 BizCharts 和 G2,该如何选择?
最近阿里正式开源的BizCharts图表库基于React技术栈,各个图表项皆采用了组件的形式,贴近React的使用特点.同时BizCharts基于G2进行封装,Bizcharts也继承了G2相关特性. ...
- html+js+css+接口交互+echarts实例一枚
1. 解决了echarts的展现 2. 解决了echarts全屏幕展现(width:100%;height:100%;) 3. 解决了向接口取数据问题 <!DOCTYPE html> &l ...
- 10个Python 统计报表/图表图形类库
matplotlib,官网:http://matplotlib.sourceforge.net/,Matplotlib 是一个由 John Hunter 等开发的,用以绘制二维图形的 Python 模 ...
- Webstorm+Webpack+echarts构建个性化定制的数据可视化图表&&两个echarts详细教程(柱状图,南丁格尔图)
Webstorm+Webpack+echarts ECharts 特性介绍 ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(I ...
- Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验
Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出E ...
- 10 款强大的JavaScript图表图形插件推荐
转自:http://www.iteye.com/news/24535 网上有很多用于绘制图表图形的免费JavaScript插件和图表库,这类插件大量出现的原因,一是人们不再依赖于Flash,二是浏览器 ...
随机推荐
- qgis cookbook-QgsMapRendererJob学习
学习到渲染(QgsMapRendererJob),按照教程所讲总是输出不了图像,看了一下qgis的测试源码,发现少了一句话,加上后就可以输出了! from qgis.core import * fro ...
- Spring源码解读(一):Spring的背景起源及框架整体介绍
一.前言 Spring起源于2002年Rod Johnson写的一本书<Expert One-on-One J2EE>,书里介绍了Java企业应用程序开发情况,并指出Java EE和EJB ...
- Xpath运算符
5.position定位 >>print tree.xpath('//*[@id="testid"]/ol/li[position()=2]/text()')[0] & ...
- python解释器的下载与安装
python解释器 1. 什么是python解释器 用一种能让电脑听的懂得语言,使得电脑可以听从人们的指令去进行工作(翻译官) Python解释器本身也是个程序, 它是解释执行Python代码的,所以 ...
- Java学习笔记:GUI基础
一:我们使用到的java GUI的API可以分为3种类: 组件类(component class) 容器类(container class) 辅助类(helper class) 1:组件类:组件类是用 ...
- 3组-Alpha冲刺-1/6
一.基本情况 队名:发际线和我作队 组长博客:链接 小组人数:10 二.冲刺概况汇报 黄新成(组长) 过去两天完成了哪些任务 文字描述 组织会议,讨论了alpha冲刺的分工,确定了收集数据的渠道,为拍 ...
- .net工程师学习vue的心路历程(三)
vue cli3没记错的话是在2019年8月份yyx个人正式声明发布. 接下来就开始我们的vue cli3的方式创建vue项目.明白一点,vue cli3遵循的一个原则就是 "0配置&quo ...
- [bzoj5340]假面
修改:维护g[i][j]表示第i个数为j的概率,从前往后转移 转移方程:g[id][i]=g[id][i-1]*p+g[id][i]*(1-p),初始g[i][a[i]]=1 询问:对于每一个人i,输 ...
- 高并发异步解耦利器:RocketMQ究竟强在哪里?
上篇文章消息队列那么多,为什么建议深入了解下RabbitMQ?我们讲到了消息队列的发展史: 并且详细介绍了RabbitMQ,其功能也是挺强大的,那么,为啥又要搞一个RocketMQ出来呢?是重复造轮子 ...
- 实用QPS和TPS高的高效分析方法
现在主库的MySQL的QPS一直在3K/s左右,想知道其到底执行了那些SQL,或者是那些SQL执行的次数比较多: 腾讯云的后台监控: 开启腾讯云的SQL审计后,下载几分钟SQL日志文件, 下列语句在M ...