excel2007 打开模板文件时不能显示chart对象的解决办法

VBA宏定义如下:

    ActiveSheet.ChartObjects("图表 2").Activate
    ActiveChart.PlotArea.Select
    ActiveSheet.ChartObjects("图表 1").Activate
    ActiveChart.PlotArea.Select

 

#include "excel8.h"
void CChartView::OnInsertChart()
{
CChartCntrItem* pItem = NULL;
//获取与视图相关的文档
CChartDoc* pDoc = GetDocument();
//创造一个新项(COleClientItem),代表新插入的OLE对象
pItem = new CChartCntrItem(pDoc);

//插入一个Excel图表
CLSID clsid;
::CLSIDFromProgID(L"Excel.Chart",&clsid);
pItem->CreateNewItem(clsid);

//为新增的图标准备显示区域
CRect rectView;
this->GetClientRect(&rectView);
//得到OLE对象(EXCEL图表)的调度接口,以便对之进行自动化控制
LPDISPATCH lpDisp;
lpDisp = pItem->GetIDispatch();
COleVariant vOpt(DISP_E_PARAMNOTFOUND, VT_ERROR);
_Workbook oBook;
oBook.AttachDispatch(lpDisp);

//获取工作表和图表
Worksheets oSheets = oBook.GetWorksheets();
//获取工作簿的第一张工作表
_Worksheet oSheet = oSheets.GetItem(COleVariant((short)1));
BeginWaitCursor();
Charts oCharts = oBook.GetCharts();
//在自动化过程隐藏图表
oSheet.SetVisible(FALSE);
//获取工作簿的图表
_Chart oChart = oCharts.GetItem(COleVariant((short)1));
//清除工作表上的所有数据
Range oRng = oSheet.GetCells();
oRng.Clear();
//设置第一列标题
oRng = oSheet.GetRange(COleVariant("A1"), vOpt);
oRng.SetValue(COleVariant("月份"));
//设置第二列标题
oRng = oSheet.GetRange(COleVariant("B1"), vOpt);
oRng.SetValue(COleVariant("销售额"));
//设置第一列的数据:月份
CString tmp,rg;
//设置A2到A13的单元内容
for(int i=1;i<=12;i++)
{
tmp.Format("%d月份",i);
rg.Format("A%d:A%d",i+1,i+1);
oRng = oSheet.GetRange(COleVariant(rg), vOpt);
oRng.SetValue(COleVariant(tmp));
}
//设置第二列数据
oRng = oSheet.GetRange(COleVariant("B2:b13"), vOpt);
//设置每个单元格的内容为=RAND()*10000
oRng.SetFormula(COleVariant("=RAND()*10000"));

//设置图表类型为三维圆饼图xl3DPieExploded
oChart.SetChartType((long)70);
//设置数据源区域
oRng = oSheet.GetRange(COleVariant("A1:B13"), vOpt);
//数据序列产生在列xlColumns=2
oChart.SetSourceData(oRng,
COleVariant((short)2));

//加入图标标题
oChart.SetHasTitle(TRUE);
ChartTitle oChartTtl = oChart.GetChartTitle();
oChartTtl.SetText("<-销售收入分月统计图->");
oChartTtl.SetShadow(TRUE);
//不使用图例
oChart.SetHasLegend(FALSE);
//设置图表区的背景颜色
PlotArea oPlot = oChart.GetPlotArea();

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值