当前位置: 首页 > news >正文

网页ui设计作品欣赏周口seo公司

网页ui设计作品欣赏,周口seo公司,网站建设公司如何,亚马逊网站建设特点示例(参考此处饼图修改https://www.isqqw.com/viewer?id37497) 话不多说直接上代码 此套代码可以直接再echarts官网中的此处运行 let selectedIndex ; let hoveredIndex ; option getPie3D([{name: 数学,value: 60,itemStyle: {color: #1890FF,},},{…

示例(参考此处饼图修改https://www.isqqw.com/viewer?id=37497)

在这里插入图片描述

话不多说直接上代码

此套代码可以直接再echarts官网中的此处运行

在这里插入图片描述

let selectedIndex = '';
let hoveredIndex = '';
option = getPie3D([{name: '数学',value: 60,itemStyle: {color: '#1890FF',},},{name: '难啊',value: 44,itemStyle: {color: '#1EE7E7',},},],0.9    // 可做为调整内环大小
);
// 生成扇形的曲面参数方程
function getParametricEquation(startRatio, endRatio, isSelected, isHovered, k, h) {// 计算const midRatio = (startRatio + endRatio) / 2;const startRadian = startRatio * Math.PI * 2;const endRadian = endRatio * Math.PI * 2;const midRadian = midRatio * Math.PI * 2;// 如果只有一个扇形,则不实现选中效果。if (startRatio === 0 && endRatio === 1) {// eslint-disable-next-line no-param-reassignisSelected = false;}// 通过扇形内径/外径的值,换算出辅助参数 k(默认值 1/3)// eslint-disable-next-line no-param-reassignk = typeof k !== 'undefined' ? k : 1 / 3;// 计算选中效果分别在 x 轴、y 轴方向上的位移(未选中,则位移均为 0)const offsetX = isSelected ? Math.cos(midRadian) * 0.1 : 0;const offsetY = isSelected ? Math.sin(midRadian) * 0.1 : 0;// 计算高亮效果的放大比例(未高亮,则比例为 1)const hoverRate = isHovered ? 1.05 : 1;  // 可以做为调整外环大小// 返回曲面参数方程return {u: {min: -Math.PI,max: Math.PI * 3,step: Math.PI / 32,},v: {min: 0,max: Math.PI * 2,step: Math.PI / 20,},x(u, v) {if (u < startRadian) {return offsetX + Math.cos(startRadian) * (1 + Math.cos(v) * k) * hoverRate;}if (u > endRadian) {return offsetX + Math.cos(endRadian) * (1 + Math.cos(v) * k) * hoverRate;}return offsetX + Math.cos(u) * (1 + Math.cos(v) * k) * hoverRate;},y(u, v) {if (u < startRadian) {return offsetY + Math.sin(startRadian) * (1 + Math.cos(v) * k) * hoverRate;}if (u > endRadian) {return offsetY + Math.sin(endRadian) * (1 + Math.cos(v) * k) * hoverRate;}return offsetY + Math.sin(u) * (1 + Math.cos(v) * k) * hoverRate;},z(u, v) {// if (u < -Math.PI * 0.5) {//     return Math.sin(u);// }// if (u > Math.PI * 2.5) {//     return Math.sin(u) * h * 0.1;// }// 当前图形的高度是Z根据h(每个value的值决定的)return 1.3 * Math.sin(v)// return Math.sin(v) > 0 ? 1 * h * 0.1 : -1;},};
}
// 生成模拟 3D 饼图的配置项
function getPie3D(pieData, internalDiameterRatio) {const series = [];// 总和let sumValue = 0;let startValue = 0;let endValue = 0;const legendData = [];const k =typeof internalDiameterRatio !== 'undefined'? (1 - internalDiameterRatio) / (1 + internalDiameterRatio): 1 / 3;// 为每一个饼图数据,生成一个 series-surface 配置for (let i = 0; i < pieData.length; i += 1) {sumValue += pieData[i].value;const seriesItem = {name: typeof pieData[i].name === 'undefined' ? `series${i}` : pieData[i].name,type: 'surface',parametric: true,wireframe: {show: false,},pieData: pieData[i],pieStatus: {selected: false,hovered: false,k,},};if (typeof pieData[i].itemStyle !== 'undefined') {const { itemStyle } = pieData[i];// eslint-disable-next-line no-unused-expressionstypeof pieData[i].itemStyle.color !== 'undefined' ? (itemStyle.color = pieData[i].itemStyle.color) : null;// eslint-disable-next-line no-unused-expressionstypeof pieData[i].itemStyle.opacity !== 'undefined'? (itemStyle.opacity = pieData[i].itemStyle.opacity): null;seriesItem.itemStyle = itemStyle;}series.push(seriesItem);}// 使用上一次遍历时,计算出的数据和 sumValue,调用 getParametricEquation 函数,// 向每个 series-surface 传入不同的参数方程 series-surface.parametricEquation,也就是实现每一个扇形。console.log(series);for (let i = 0; i < series.length; i += 1) {endValue = startValue + series[i].pieData.value;series[i].pieData.startRatio = startValue / sumValue;series[i].pieData.endRatio = endValue / sumValue;series[i].parametricEquation = getParametricEquation(series[i].pieData.startRatio,series[i].pieData.endRatio,false,false,k,// 我这里做了一个处理,使除了第一个之外的值都是10series[i].pieData.value === series[0].pieData.value ? 10 : 10);startValue = endValue;legendData.push(series[i].name);}// 准备待返回的配置项,把准备好的 legendData、series 传入。const option = {legend:{show: true},title: {text: '3D 曲状饼图展示',x: 'center',top:170,textStyle: {color: '#000',fontSize: 14,}},// animation: false,tooltip: {formatter: (params) => {if (params.seriesName !== 'mouseoutSeries') {return `${params.seriesName}<br/><span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${params.color};"></span>${option.series[params.seriesIndex].pieData.value}`;}return '';},},xAxis3D: {min: -1,max: 1,},yAxis3D: {min: -1,max: 1,},zAxis3D: {min: -1,max: 1,},grid3D: {show: false,boxHeight: 5,top: '-20%',viewControl: {// 3d效果可以放大、旋转等,请自己去查看官方配置alpha: 20,// beta: 30,rotateSensitivity: 1,zoomSensitivity: 0,panSensitivity: 0,autoRotate: true,distance: 300,},// 后处理特效可以为画面添加高光、景深、环境光遮蔽(SSAO)、调色等效果。可以让整个画面更富有质感。postEffect: {// 配置这项会出现锯齿,请自己去查看官方配置有办法解决enable: false,bloom: {enable: true,bloomIntensity: 0.1,},SSAO: {enable: true,quality: 'medium',radius: 2,},// temporalSuperSampling: {//   enable: true,// },},},series,};return option;
}
// //  修正取消高亮失败的 bug
// // 监听 mouseover,近似实现高亮(放大)效果
// option.title.text = option.series[0].name + ' '+option.series[0].pieData.value
// function handleOver(params) {
//         // 准备重新渲染扇形所需的参数
//     let isSelected;
//     let isHovered;
//     let startRatio;
//     let endRatio;
//     let k;
//     let i;//     // 如果触发 mouseover 的扇形当前已高亮,则不做操作
//     if (hoveredIndex === params.seriesIndex) {
//         return;//         // 否则进行高亮及必要的取消高亮操作
//     } else {
//         // 如果当前有高亮的扇形,取消其高亮状态(对 option 更新)
//         if (hoveredIndex !== '') {
//             // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 false。
//             isSelected = option.series[hoveredIndex].pieStatus.selected;
//             isHovered = false;
//             startRatio = option.series[hoveredIndex].pieData.startRatio;
//             endRatio = option.series[hoveredIndex].pieData.endRatio;
//             k = option.series[hoveredIndex].pieStatus.k;
//             i = option.series[hoveredIndex].pieData.value === option.series[0].pieData.value ? 35 : 10;
//             // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
//             option.series[hoveredIndex].parametricEquation = getParametricEquation(
//                 startRatio,
//                 endRatio,
//                 isSelected,
//                 isHovered,
//                 k,
//                 i
//             );
//             option.series[hoveredIndex].pieStatus.hovered = isHovered;//             // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
//             hoveredIndex = '';
//         }//         // 如果触发 mouseover 的扇形不是透明圆环,将其高亮(对 option 更新)
//         if (params.seriesName !== 'mouseoutSeries') {
//              option.title.text=' ' +option.series[seriesIndex].name + ' ' + option.series[params.seriesIndex].pieData.value
//             // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
//             isSelected = option.series[params.seriesIndex].pieStatus.selected;
//             isHovered = true;
//             startRatio = option.series[params.seriesIndex].pieData.startRatio;
//             endRatio = option.series[params.seriesIndex].pieData.endRatio;
//             k = option.series[params.seriesIndex].pieStatus.k;//             // 对当前点击的扇形,执行高亮操作(对 option 更新)
//             option.series[params.seriesIndex].parametricEquation = getParametricEquation(
//                 startRatio,
//                 endRatio,
//                 isSelected,
//                 isHovered,
//                 k,
//                 option.series[params.seriesIndex].pieData.value + 5
//             );
//             option.series[params.seriesIndex].pieStatus.hovered = isHovered;//             // 记录上次高亮的扇形对应的系列号 seriesIndex
//             hoveredIndex = params.seriesIndex;
//         }//         // 使用更新后的 option,渲染图表
//         myChart.setOption(option);
//     }
// }
// myChart.on('mouseover', function (params) {
//     handleOver(params)
// });// function handleOut() {
//        if (hoveredIndex !== '') {
//         // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
//         isSelected = option.series[hoveredIndex].pieStatus.selected;
//         isHovered = false;
//         k = option.series[hoveredIndex].pieStatus.k;
//         startRatio = option.series[hoveredIndex].pieData.startRatio;
//         endRatio = option.series[hoveredIndex].pieData.endRatio;
//         // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
//         i = option.series[hoveredIndex].pieData.value === option.series[0].pieData.value ? 35 : 10;
//         option.series[hoveredIndex].parametricEquation = getParametricEquation(
//             startRatio,
//             endRatio,
//             isSelected,
//             isHovered,
//             k,
//             i
//         );
//         option.series[hoveredIndex].pieStatus.hovered = isHovered;//         // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
//         hoveredIndex = '';
//     }//     // 使用更新后的 option,渲染图表
//     myChart.setOption(option);
// }
// // 修正取消高亮失败的 bug
// myChart.on('globalout', function () {
//     handleOut()
// });
// console.log(option)
// let seriesIndex = 0 
// setInterval(() => {
//     handleOver({seriesIndex:seriesIndex})
//     seriesIndex++
//     if (seriesIndex === option.series.length) {
//         seriesIndex = 0
//     }
// }, 3000)
http://www.yidumall.com/news/56651.html

相关文章:

  • 桐城58网站在那里做域名服务器查询
  • 涛哥快速建站网站点击排名优化
  • 佛山门户网站建设世界杯最新排名
  • 列举常用动态网站开发技术seo站长
  • 百度上找不到网站竞价是什么工作
  • 广东哪家网站建宁波seo教程app推广
  • 大连个人做网站2023b站推广大全
  • 黄石做网站要多少钱中国企业网官方网站
  • 有没有便宜的注册代理如何优化网络连接
  • 制作网站的过程细节百度识图官网
  • 延安网站建设推广微信网站湖南seo优化公司
  • 有谁做过网站建设品牌策划方案怎么写
  • 在百度上做网站怎么做长沙网络营销学校
  • 个人建网站要花多少钱bt种子万能搜索神器
  • 滨州网站建设 远洋科技排名优化公司
  • 老域名查询网站seo去哪个网站找好
  • 免费网站建设教程百度seo优化规则
  • 郑州web网站建设公司怎么制作网站?
  • 网站优化的常见问题外汇交易平台
  • 有必要自建网站做导购吗刷百度关键词排名优化
  • 如何做微信朋友圈网站株洲发布最新通告
  • wordpress dux主题设置首页网站手机版排名seo
  • 为什么要建设应急管理网站有什么可以做推广的软件
  • 那些网站可以做h5沈阳seo排名收费
  • 不懂代码如何做网站百度搜索引擎seo
  • 正规的网站制作在哪里搜索引擎优化的主要手段
  • 在线酒店预定网站制作电子商务网站建设流程
  • 有什么网站可以做初中试题上海网站制作推广
  • 长沙优化网站哪家公司好百度推广网址
  • 国外做网站推广银川网站seo