Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共15 条记录, 每页显示 10 条, 页签: [1] [2]
[浏览完整版]

标题:Echarts模拟大屏装入Foxtable分享与问题

1楼
douglas738888 发表于:2022/1/20 13:48:00
最近,在学习Echarts,并尝试做了一个时下流行的大数据大屏,并应用到Foxtable中,目前效果还不错,感谢本论坛老师的帮助
先上图,再交流一下所遇到的坑,最后有几个问题还要请教老师。


此主题相关图片如下:大屏.jpg
按此在新窗口浏览图片

使用第三方工具visual studio code完成代码后,通过FoxtableHttpReuest事件和WebBrowser控件展示出来,尽管还有很多需要改善和完善的地方,但总体还是很高大上的。


当然,只有用心学习,Foxtable也能实现类似的效果,这是我们用Foxtable完成的一个项目例子,也与大家共同交流


此主题相关图片如下:例子.jpg
按此在新窗口浏览图片

以下,大家共同交流

 

1. 认真学习一些最基础的EchartsJavaCSShtml......的相关知识,知晓最基本的概念,否则n个坑等你去跳,有些坑原来论坛有的朋友已经说过

2. 认真学习Foxtable的帮助和高级指南,一定有很大帮助的,也不能完全照搬,要举一反三的去做

 

跳坑友情提示:(这些坑,自己跳了好几个星期才爬上来;多浏览某度学习)

1. 浏览器的选择,目前常用的浏览器有IEedge、火狐、谷歌,个人建议调试使用edge或谷歌的比较好,因为开发者工具提示完善一些;

   各个浏览器对htmlbody的显示比例对大屏的呈现有所不同,需要根据具体场景进行代码的修改适配;在edge上能显示的,未必在IE91011

   上能达到效果;Foxtable内核是IE浏览器,这个需要进行注意;特别是有某些CSS3/5动画效果,edge可以,在IE11上无效果(可能是自己水平不行)

2. 要理解、搞清楚utf8以及http-equiv="X-UA................",否则,在edge上展示ok,但在WebBrowser上很难展示原来设计的效果

3. 如果是写码高手,自然选用好的编程工具,我水平低使用的是visual studio code;写码时候特别注意每一个”{}““...的写法和规则,特别是html的规则

   开始学习时,报错不断,很烧脑;visual studio code要注意安装必要的插件,否则,一定让你难看

4. IE浏览器上显示的字体与其他浏览器会有所不同,这个要注意;比如:要想使用LED字体或电子版字体,有的字体能@font-face声明成功,有的就是不行比如:DS-Digital.ttf这个字体,在edge上没有问题,在IE上就是宋体显示(支持eot格式字体);DS-Digital.ttf这个字体用eot转换工具就是无法转换出来

5. 只是展示Echarts的单个图表的数据生成并配合Foxtable使用,用论坛蓝老师给的小例完全可以满足;如果是多个组合图表的动态异步数据加载展示,会用到json,并涉及到相关版本的jquery.js,以及相关函数的用法等等

6.如果要使用中国地图,那么Echarts上的china.js被国家有关部门进行禁止的;我仔细查了相关资料,主要是新疆、南海诸岛、钓鱼岛的显示有错误,一定要使用map的注意要自己在代码上进行修改,显示出南海诸岛和钓鱼岛(部分china.js已修正新疆部分和南海诸岛,可以使用,但必须自己加上钓鱼岛)

7. 引入相关必要的js文件是,要注意排序位置,必然jquery.min.js需要排序在echarts.min.js上下,这两个js引入位置最好在最前面,用edge时,jquery.min.js位置顺序在调试时会有影响;在FoxtableHttpReuest事件中没有影响,这个我不知道为什么。这些相关文件很多Echarts已经停止http的链接,最好下载到本地进行引用

8.引入js文件或相关url本地文件时一定注意路径的准确;比如:./  ../  /web/lib等都有不同,要特别注意,否则一定报错

9.使用编程工具时,有些代码中的单引号,我基本都改为规则应该的双引号,这样基本不出错,当然在Foxtable中根据规则使用

10.当用到ajax$get 调用json数据时,这个是很多专业程序员头疼的问题,必然绕不开浏览器跨域的问题,主要是相关浏览器考虑到安全的问题,不允许调用本地文件;本机调试时,一定要写入例如127.0.0.15500(各电脑不同,端口会有所不同,有的是8800IE的是7000等等)路径;如果使用visual studio code,一定安装插件,并开启Live,根据显示的未占有的端口进行调试路径的配置;

比如:

     蓝老师小例(HttpReuest事件)使用map.js文件中的代码

 $.get("getdata.html?type=2").done(function (jsonstr)

     visual studio code调试的代码

$.get('http://127.0.0.1:5501/web/lib/data2.txt').done(function (jsonstr)

端口关闭,一定调用不到相关json数据,如何开口端口,Foxtable高级知道一读并知

11. 在相关浏览器调试时,多用检查以及相关开发者工具,并识读报错提示,并进行修正代码;当然有的错误提示,不是单一的,会与多个部分联动,修改一个bug,其他代码部分就自然合理允许,这个需要多学习才能知晓,总之这样的坑并不少

12. 学习过程不能操之过急,一步一步来,一个问题一个问题解决,我的大屏心得是:

12.1 学习基本EchartsJavaCSShtml知识,根据例子进程学习

12.2 准备工具,准备文件,准备素材,准备例子

12.3  htmlless引文件,引图片,画盒子,分区,写标头 body基本完成

12.4  js写函数,写实例,指定配置项和数据,图表跟随屏幕适配,进程调试

12.5  静态数据整体调试,修改

12.6  ajax调用动态json数据,装入Foxtable调试/修改

12.7 等待例子项目发布测试,目前还未发布进行测试

 

目前问题请教:

Json数据或txt数据修改某个数据后,在FoxtableWebBrowser控件展示时,图表不能及时响应已修改的数据,但是直接打开edgeIE浏览器,图表数据已经及时响应满足要求;Foxtable中无论是关闭窗口,还是点击按钮,图表都不会及时响应已修改的数据

(我用蓝老师的小例测试,也是这个问题)

例如:button click

Dim brw As WinForm.WebBrowser = e.Form.Controls("WebBrowser1")

brw.Address = http://127.0.0.1/indexAA.html

 

如果这样写代码,修改jsontxt中的数据后,重新打开窗口才能正常显示已修改的数据

Dim brw As WinForm.WebBrowser = e.Form.Controls("WebBrowser1")

brw.Address = http://127.0.0.1/indexAA.html

brw.Address = http://127.0.0.1/indexAA.html

 

请教老师,在Foxtable窗口中的刷新方式怎样写代码合适

 

我在html写代码不行

<meta http-equiv=”refresh” content=”20″>


这样写不符合要求

<script language=”JavaScript”>

    function myrefresh(){

        window.location.reload();

    }

    setTimeout(‘myrefresh(),1000); //指定1秒刷新一次

</script>

 

我在js中这样写也不行

(function () {

    var myChart = echarts.init(document.querySelector

        (".bar .chart"));  //1个盒子 Panel bar chart

 

    setInterval(function () {

        $.get("getdata.html?type=2").done(function (jsonstr) {

            var mydata = eval("(" + jsonstr + ")");

 

            myChart.setOption({

                color: ["#2f89cf"],

                tooltip: {

                    trigger: "axis",

                    axisPointer: {

                        // 坐标轴指示器,坐标轴触发有效

                        type: "shadow"

                    },

 

                    // 提示框浮层属性

                    backgroundColor: "rgba(50,50,50,0.8)",  //背景颜色

                    borderColor: "#2b8ae3", // 边框颜色

                    borderWidth: 0.5,  // 边框宽

                    padding: 5,       // 内边距

 

                    textStyle: {      // 文本样式。

                        color: "#ffffff",

                        fontStyle: "normal",

                        fontWeight: "normal",

                        fontFamily: "宋体",

                        fontSize: 16

                    }

                },

 

                // 修改图表的大小

                grid: {

                    left: "0",

                    top: "10px",

                    right: "0px",

                    bottom: "4%",

                    containLabel: true

                },

 

                xAxis: [

                    {

                        type: "category",

                        data: mydata.categories,

                        axisTick: {

                            alignWithLabel: true

                        },

                        //修改刻度标签

                        axisLabel: {

                            color: "rgba(250,250,250,0.9)",

                            fontSize: "9",

                            fontFamily: "宋体"

                        },

                        // 不显示X坐标轴的样式

                        axisLine: {

                            show: false

                        }

                    }

                ],

 

                yAxis: [

                    {

                        type: "value",

                        // 修改刻度标签

                        axisLabel: {

                            color: "rgba(250,250,250,0.6)",

                            fontSize: "12"

                        },

                        // Y轴线条改2像素

                        axisLine: {

                            lineStyle: {

                                color: "rgba(250,250,250,0.1)",

                                width: 2

                            }

                        },

                        // Y轴分割线颜色

                        splitLine: {

                            lineStyle: {

                                color: "rgba(250,250,250,0.1)"

                            }

                        }

                    }

                ],

 

                series: [

                    {

                        name: "Direct",

                        type: "bar",

                        barWidth: "35%",

                        data:mydata.data,                       

itemStyle: {

                            barBorderRadius: 4

                        }

                    }

                ]

            });

 

            // 4 让图表跟随屏幕自动适应

            window.addEventListener("resize", function () {

                myChart.resize();

            });

        });

    }, 3000);

})();

 


2楼
有点蓝 发表于:2022/1/20 13:53:00
刷新当前页面

Dim brw As WinForm.WebBrowser = e.Form.Controls("WebBrowser1")
brw.refresh
3楼
xndd 发表于:2022/1/20 20:38:00
应该是javascript
4楼
lisangyu 发表于:2022/1/21 10:30:00
点赞,希望作者能分享一下,这个非常实用,谢谢!
5楼
douglas738888 发表于:2022/1/21 12:43:00
可以先看看蓝老师的这个小例 http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=103519&replyID=&skin=1
6楼
小美菜 发表于:2022/1/21 12:56:00
牛X了,我也计划要做,到时向你学习
7楼
忆似水流年 发表于:2022/1/21 13:09:00
 感谢分享
8楼
fivetable 发表于:2022/1/21 14:48:00
不发源码来给狐友们分享,不给赞!!!
9楼
xnsiwei 发表于:2022/2/15 23:31:00
正在学习
10楼
浙江仔 发表于:2022/2/16 16:44:00
狐表的WebBrowser控件,哎
共15 条记录, 每页显示 10 条, 页签: [1] [2]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .03906 s, 2 queries.