请选择 进入手机版 | 继续访问电脑版
 找回密码
 立即注册

QQ登录

只需一步,快速开始

zhouwenchun

注册会员

6

主题

12

帖子

48

积分

注册会员

积分
48
最新发帖
zhouwenchun
注册会员   /  发表于:2019-5-21 20:43  /   查看:4342  /  回复:3


1.附件是我测试的excel,导入到页面,图片显示是正常的,我将excel中图片复制出来放到项目里,调用以下代码将图片放到页面上,图片尺寸明显不同,该如何写可以正常显示(像导入excel时图片显示的一样)
  1.     $("#sign").click(function() {
  2.                                         var spread = GC.Spread.Sheets.findControl(document.getElementById('ss'));
  3.                                         var sheet = spread.getActiveSheet();
  4.                                         var spreadNS = GC.Spread.Sheets;
  5.                                         var SheetArea = spreadNS.SheetArea;
  6.                                         //获取可视化区域行数和列数
  7.                                         //                                        var rowcount = sheet.getRowCount();
  8.                                         //                                        var columncount = sheet.getColumnCount();
  9.                                         //遍历计算可视化区域宽高(px)
  10.                                         var width = 0,
  11.                                                 height = 0;
  12.                                         var sheet = spread.getSheet(0);
  13.                                         console.log('当前选中区域', sheet.getSelections());
  14.                                         var rowCount = sheet.getSelections()[0].row;
  15.                                         var colCount = sheet.getSelections()[0].col;
  16.                                         for(var i = 0; i < rowCount; i++) {
  17.                                                 height += sheet.getRowHeight(i, SheetArea.viewport);;
  18.                                         }
  19.                                         for(var i = 0; i < colCount; i++) {
  20.                                                 width += sheet.getColumnWidth(i, SheetArea.viewport);;
  21.                                         }
  22.                                         console.log("行数:", rowCount);
  23.                                         console.log("列数:", colCount);
  24.                                         console.log("宽:", width);
  25.                                         console.log("高", height);
  26.                                         var img = new Image();
  27.                                         img.src = "img/sign.png";
  28.                                         img.onload = function() {
  29.                                                 var imgwidth = img.naturalWidth;
  30.                                                 var imgheight = img.naturalHeight;
  31.                                                 var uid = uuid();
  32.                                                 sheet.pictures.add(uid, "img/sign.png", width, height, imgwidth, imgheight);
  33.                                         }
  34.                                 })
复制代码

2.我导出时,上面代码加的那个图片咋导不出来,代码如下
  1. $("#export").click(function() {
  2.                                         var excelIo = new GC.Spread.Excel.IO();
  3.                                         var fileName = "测试导出.xlsx";
  4.                                         var aa= GC.Spread.Sheets.findControl(document.getElementById('ss'));
  5.                                         var json = aa.toJSON();
  6.                                         // here is excel IO API
  7.                                         excelIo.save(json, function(blob) {
  8.                                                 saveAs(blob, fileName);
  9.                                         });
  10.                                 })
复制代码


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

3 个回复

倒序浏览
KevinChen讲师达人认证 悬赏达人认证 SpreadJS 开发认证
论坛元老   /  发表于:2019-5-22 17:08:19
沙发
您好,您的问题回答如下:

1、您在代码中调用了img的naturalWidth和naturalHeight,然而实际上在Excel和SpreadJS中,图片都是设置过尺寸的。
针对您的问题,您可以采用这样的思路:圈定一个区域,比如n行、m列,用代码设置图片尺寸,如图:

参考API:
https://demo.grapecity.com.cn/sp ... bjects.Picture.html

2、要将图片导出到Excel中,不能只添加"img/sign.png"这样的引用,而是把图片转为Base64编码传入add方法的第二个参数,见下列代码所示:
  1. var pic = "";

  2. var spread = GC.Spread.Sheets.findControl("ss");
  3. var sheet = spread.getActiveSheet();
  4. sheet.pictures.add("f5", pic, 100, 100, 100, 100);
复制代码

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复 使用道具 举报
zhouwenchun
注册会员   /  发表于:2019-5-23 15:36:15
板凳
如果Excel和SpreadJS中图片都是设置过尺寸的,我的图片宽高应该设置成多少才能是Excel和SpreadJS中图片的尺寸呢
回复 使用道具 举报
KevinChen讲师达人认证 悬赏达人认证 SpreadJS 开发认证
论坛元老   /  发表于:2019-5-23 18:17:04
地板
您好,这个是根据您所需要的尺寸来定义的,用SpreadJS导入Excel时会拿到Excel中定义图片的尺寸,但是您用代码添加图片,就需要根据图片所需区域定义尺寸。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 立即注册
返回顶部