日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 人文社科 > 生活经验 >内容正文

生活经验

在asp.net中调用Office来制作各种(3D)统计图

發(fā)布時(shí)間:2023/11/27 生活经验 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 在asp.net中调用Office来制作各种(3D)统计图 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
作者:未知?? 由于本文網(wǎng)上多處見(jiàn)到 對(duì)于誰(shuí)是作者 無(wú)法肯定

?

?

1、下載owc11 COM組件

http://www.microsoft.com/downloads/details.aspx?FamilyID=7287252c-402e-4f72-97a5-e0fd290d4b76&displaylang=en?

2、注冊(cè)owc11

? 在工程中添加 C:/Program Files/Common Files/Microsoft Shared/Web Components/11? 文件下的owc11.dll引用? 或者按如下圖所以添加com

?

3、在工程中添加

??? using OWC11;

4、開(kāi)始coding? 舉例如下:

?

?public class ChartFactory
?{
??public ChartFactory()
??{
???InitTypeMap();
???//
???// TODO: 在此處添加構(gòu)造函數(shù)邏輯
???//
??}
??protected System.Web.UI.WebControls.Image imgHondaLineup;
??private string[] chartCategoriesArr;
??private string[] chartValuesArr;
??private OWC11.ChartChartTypeEnum chartType =? OWC11.ChartChartTypeEnum.chChartTypeColumn3D;//默認(rèn)值
??private static Hashtable chartMap = new Hashtable();
??private static string chartTypeCh = "垂直柱狀圖" ;
??private static string chartTitle = "";

??private void InitTypeMap()
??{
???chartMap.Clear();
???OWC11.ChartChartTypeEnum[] chartTypes = new OWC11.ChartChartTypeEnum[]{ ChartChartTypeEnum.chChartTypeColumnClustered,
????????????????????ChartChartTypeEnum.chChartTypeColumn3D,
????????????????????ChartChartTypeEnum.chChartTypeBarClustered,
????????????????????ChartChartTypeEnum.chChartTypeBar3D,
????????????????????ChartChartTypeEnum.chChartTypeArea,
????????????????????ChartChartTypeEnum.chChartTypeArea3D,
????????????????????ChartChartTypeEnum.chChartTypeDoughnut,
????????????????????ChartChartTypeEnum.chChartTypeLineStacked,
????????????????????ChartChartTypeEnum.chChartTypeLine3D,
????????????????????ChartChartTypeEnum.chChartTypeLineMarkers,
????????????????????ChartChartTypeEnum.chChartTypePie,
????????????????????ChartChartTypeEnum.chChartTypePie3D,
????????????????????ChartChartTypeEnum.chChartTypeRadarSmoothLine,
????????????????????ChartChartTypeEnum.chChartTypeSmoothLine};
???string[] chartTypesCh = new string [] {"垂直柱狀統(tǒng)計(jì)圖","3D垂直柱狀統(tǒng)計(jì)圖","水平柱狀統(tǒng)計(jì)圖","3D水平柱狀統(tǒng)計(jì)圖","區(qū)域統(tǒng)計(jì)圖","3D區(qū)域統(tǒng)計(jì)圖","中空餅圖","折線統(tǒng)計(jì)圖","3D折線統(tǒng)計(jì)圖","折線帶點(diǎn)統(tǒng)計(jì)圖","餅圖","3D餅圖","網(wǎng)狀統(tǒng)計(jì)圖","弧線統(tǒng)計(jì)圖"};
???
???for(int i=0;i<chartTypes.Length;i++)
???{
????chartMap.Add(chartTypesCh[i],chartTypes[i]);
???}
??}

??public ChartSpaceClass BuildCharts ()
??{
???string chartCategoriesStr = String.Join ("/t", chartCategoriesArr);
???string chartValuesStr = String.Join ("/t", chartValuesArr);

???OWC11.ChartSpaceClass?????? oChartSpace = new OWC11.ChartSpaceClass ();

???// ------------------------------------------------------------------------
???// Give pie and doughnut charts a legend on the bottom. For the rest of
???// them let the control figure it out on its own.
???// ------------------------------------------------------------------------

???chartType = (ChartChartTypeEnum)chartMap[chartTypeCh];

???if (chartType == ChartChartTypeEnum.chChartTypePie ||
????chartType == ChartChartTypeEnum.chChartTypePie3D ||
????chartType == ChartChartTypeEnum.chChartTypeDoughnut)
???{
????oChartSpace.HasChartSpaceLegend = true;
????oChartSpace.ChartSpaceLegend.Position = ChartLegendPositionEnum.chLegendPositionBottom;
???}

???oChartSpace.Border.Color = "blue";
???oChartSpace.Charts.Add(0);
???oChartSpace.Charts[0].HasTitle = true;
???oChartSpace.Charts[0].Type = chartType;
???oChartSpace.Charts[0].ChartDepth = 125;
???oChartSpace.Charts[0].AspectRatio = 80;
???oChartSpace.Charts[0].Title.Caption = chartTitle;
???oChartSpace.Charts[0].Title.Font.Bold = true;

???oChartSpace.Charts[0].SeriesCollection.Add(0);
???oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection.Add ();

???// ------------------------------------------------------------------------
???// If you're charting a pie or a variation thereof percentages make a lot
???// more sense than values...
???// ------------------------------------------------------------------------
???if (chartType == ChartChartTypeEnum.chChartTypePie ||
????chartType == ChartChartTypeEnum.chChartTypePie3D ||
????chartType == ChartChartTypeEnum.chChartTypeDoughnut)
???{
????oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].HasPercentage = true;
????oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].HasValue = false;
???}
????// ------------------------------------------------------------------------
????// Not so for other chart types where values have more meaning than
????// percentages.
????// ------------------------------------------------------------------------
???else
???{
????oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].HasPercentage = false;
????oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].HasValue = true;
???}
???????????????
???// ------------------------------------------------------------------------
???// Plug your own visual bells and whistles here
???// ------------------------------------------------------------------------
???oChartSpace.Charts[0].SeriesCollection[0].Caption = String.Empty;
???oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].Font.Name = "verdana";
???oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].Font.Size = 10;
???oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].Font.Bold = true;
???oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].Font.Color = "red";
???oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].Position = ChartDataLabelPositionEnum.chLabelPositionCenter;
???
???if (chartType == ChartChartTypeEnum.chChartTypeBarClustered ||
????chartType == ChartChartTypeEnum.chChartTypeBar3D ||
????chartType == ChartChartTypeEnum.chChartTypeColumnClustered ||
????chartType == ChartChartTypeEnum.chChartTypeColumn3D)
???{
????oChartSpace.Charts[0].SeriesCollection[0].DataLabelsCollection[0].Position = ChartDataLabelPositionEnum.chLabelPositionOutsideEnd;
???}
???
???oChartSpace.Charts[0].SeriesCollection[0].SetData (OWC11.ChartDimensionsEnum.chDimCategories,
????Convert.ToInt32(OWC11.ChartSpecialDataSourcesEnum.chDataLiteral), chartCategoriesStr);

???oChartSpace.Charts[0].SeriesCollection[0].SetData (OWC11.ChartDimensionsEnum.chDimValues,
????Convert.ToInt32(OWC11.ChartSpecialDataSourcesEnum.chDataLiteral), chartValuesStr);

???return oChartSpace;
??}

??#region? 屬性設(shè)置
??public string[] chartCategoriesArrValue
??{
???get
???{
????return chartCategoriesArr;
???}
???set
???{
????chartCategoriesArr = value;
???}
??}

??public string[] chartValuesArrValue
??{
???get
???{
????return chartValuesArr;
???}
???set
???{
????chartValuesArr = value;
???}
??}
??public string chartTypeValue
??{
???get
???{
????return chartTypeCh;
???}
???set
???{
????chartTypeCh = value;
???}
??}
??public string chartTitleValue
??{
???get
???{
????return chartTitle;
???}
???set
???{
????chartTitle = value;
???}
??}
??#endregion
?}

?

//調(diào)用?? 首先需要在頁(yè)面上放置一個(gè)Image來(lái)顯示產(chǎn)生的統(tǒng)計(jì)圖

??public void ShowChart()
??{

//初始化賦值
???chartFactory.chartCategoriesArrValue = chartCategories;
???chartFactory.chartValuesArrValue = chartValues;
???chartFactory.chartTitleValue = chartTitle;
???chartFactory.chartTypeValue = chartType;

???OWC11.ChartSpaceClass oChartSpace = chartFactory.BuildCharts();
???string path = Server.MapPath(".") + @"/images/Chart.jpeg";??//產(chǎn)生圖片并保存 頁(yè)可以是png?gif圖片
???oChartSpace.ExportPicture(path,"jpeg", 745, 500);
???Image1.ImageUrl = path;??// 顯示統(tǒng)計(jì)圖
??}

// 保存統(tǒng)計(jì)圖請(qǐng)參照上一篇文章

//由于每次生成的統(tǒng)計(jì)圖都會(huì)覆蓋原來(lái)的圖片所以有必要的話可以用日期加時(shí)間的方式來(lái)作為圖片的名字,但是這樣將會(huì)產(chǎn)生很多圖片需及時(shí)處理,如不需要只需取同名覆蓋原來(lái)圖片即可。

總結(jié)

以上是生活随笔為你收集整理的在asp.net中调用Office来制作各种(3D)统计图的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 99久久久无码国产 | 91精品国产手机 | 欧美黑吊大战白妞欧美大片 | 欧美日韩国产成人在线 | 91人人澡人人爽 | 日本在线观看一区二区 | 久久久6 | 男女啪啪网站免费 | 国内特级毛片 | 爽爽影院在线免费观看 | 欧美精品在线视频观看 | 免费成人高清在线视频 | 美女一级黄色片 | 亚洲专区免费 | 视频黄页在线观看 | 欧洲xxxxx | 中文字幕亚洲一区二区三区五十路 | 欧美大奶在线 | 91久久国产综合久久91精品网站 | 天天射日日干 | 亲切的金子餐桌片段的金子 | 中文字幕35页 | 爱爱一区| 成人免费一区二区三区在线观看 | 色婷婷久久五月综合成人 | 一级片免费网址 | 蜜臀久久99精品久久久久久 | 欧美一级免费黄色片 | 婷婷色吧 | 毛片网站视频 | 亚洲少妇一区二区三区 | 久久97久久97精品免视看 | 婷婷丁香色 | 欧美熟妇毛茸茸 | 亚洲丝袜在线视频 | 2级黄色片| 成人黄色免费在线观看 | 伊人手机在线视频 | 特大巨交吊性xxxx | 国产激情综合五月久久 | 天天舔天天干天天操 | 中文字幕天堂网 | 四虎成人在线观看 | 91精品国产综合久久久久久 | 亚洲欧美另类自拍 | 很黄的网站在线观看 | 丰满少妇一区 | 深夜免费福利 | 亚洲不卡一区二区三区 | 永久免费精品视频 | 九九热在线精品 | a级片免费看| 性欧美bb| 免费看a级黄色片 | 国内自拍青青草 | 国产精品福利影院 | 福利片第一页 | 一区一区三区产品乱码 | 日本黄色不卡 | 四虎影视黄色 | 极品少妇xxxx精品少妇偷拍 | 亚洲精选一区二区三区 | 日韩午夜 | 91爱啪| 丁香六月色 | 国产一级一片免费播放 | 亚洲乱码国产乱码精品精98午夜 | 亚洲综合激情五月久久 | 国产伦精品一区二区三区高清版禁 | a视频在线观看免费 | 国内精品嫩模av私拍在线观看 | 中文字幕av观看 | www.中文字幕av | 亚洲自拍在线观看 | 日本一区二区精品 | 久久久久亚洲av成人毛片韩 | 国内精久久久久久久久久人 | 国产精品一区二区久久国产 | 林雅儿欧洲留学恋爱日记在线 | 日韩精品国产精品 | 噜噜噜久久久 | 亚洲人成网址 | 国产孕妇孕交大片孕 | www.日韩.com | 玉女心经 在线 | 色av一区| 久久久久久久久久久久久女国产乱 | 精品视频入口 | 青青草中文字幕 | 亚洲毛片在线看 | 免费观看国产精品视频 | 人人澡人人爽 | 在线观看av不卡 | 国产在线高清视频 | 欧美整片sss | 王者后宫yin肉h文催眠 | 亚洲精品视频一区 | 日本高清免费不卡视频 | 国产稀缺真实呦乱在线 |