反馈已提交

网络繁忙

当前为10.0版本文档,只有最新版本的文档支持在线编辑修改,如果想创建/编辑文档,请移步至 最新版帮助文档

JS实现点击单元格弹框展示可旋转图片

  • 文档创建者:936669367
  • 历史版本:4
  • 最近更新:Catqiu 于 2022-09-14
  • 1. 概述

    1.1 问题描述

    Finereport 中 toimage 函数展示的图片不能旋转,当需求是点击单元格能弹框展示图片并可旋转、放大,弹框可拖拽等,要如何实现呢?如下图所示:

    2021-02-03_11-07-26.gif


    1.2 解决思路

    单元格图片 HTML 显示 ,f引入外部 JS 和 CSS 文件。

    2. 示例

    2.1 准备文件

    准备需要的 JS 文件和 CSS 文件,见下面压缩包,解压后放置在%FR_HOME%\webapps\webroot\目录下。如下图所示:

    点击可下载:static.zip

    image.png

    2.2 准备模板

    新建模板,在 A2 单元格中添加图片地址,B2 单元格中输入 HTML 代码,选择单元格显示方式为「用HTML显示内容」。如下图所示:

    2022-09-14_9-58-47.png

    HTML 代码如下:

    '<a href="javascript:void(0)" data-magnify="gallery2" data-group="g2" data-src="' + a2 + '" data-caption="测试图片"> 点击查看 </a>'

    2.3 引入文件

    1)点击菜单栏「模板>模板Web属性>引用css」,引用放置在 webroot 目录下的 css 文件。如下图所示:

    2)点击菜单栏「模板>模板Web属性>引用JavaScript」,引用放置在 webroot 目录下的 JS文件。如下图所示:

    2.4 添加事件

    点击菜单栏「模板>模板Web属性>分页预览设置」,选择「为该模板单独设置」,添加一个「加载结束」事件:如下图所示:

    JavaScript 代码如下:

    $(function () {
    $('[data-magnify]').Magnify({
    Toolbar: [
    'prev',
    'next',
    'rotateLeft',
    'rotateRight',
    'zoomIn',
    'actualSize',
    'zoomOut'
    ],
    keyboard:true,
    draggable:true,
    movable:true,
    modalSize:[800,600],
    beforeOpen:function (obj,data) {
    console.log('beforeOpen')
    },
    opened:function (obj,data) {
    console.log('opened')
    },
    beforeClose:function (obj,data) {
    console.log('beforeClose')
    },
    closed:function (obj,data) {
    console.log('closed')
    },
    beforeChange:function (obj,data) {
    console.log('beforeChange')
    },
    changed:function (obj,data) {
    console.log('changed')
    }
    });

    })

    2.5 效果预览

    保存模板,点击「分页预览」,效果如下图所示:

    image.png

    注:不支持移动端。

    3. 模板下载

    点击下载模板和附件:

    imageTest.cpt

    static.zip

    附件列表


    主题: 报表应用
    已经是第一篇
    已经是最后一篇
    • 有帮助
    • 没帮助
    • 只是浏览

    售前咨询电话

    400-811-8890转1

    在线技术支持

    请前往「服务平台」,选择「在线支持」

    热线电话:400-811-8890转2

    总裁办24H投诉

    热线电话:173-1278-1526