Java軟件報表軟件技術博客

          java報表軟件技術匯總 java報表軟件制作 報表軟件新聞
          posts - 355, comments - 100, trackbacks - 0, articles - 3
             :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

          在日常使用地圖過程中,通常會遇到地圖標簽,提示點等顯示不滿足我們的需求,需要進行JavaScript代碼編寫。

          例如:在使用地圖過程中,會發現很多地名顯示的位置偏離。這時候就需要使用JavaScript進行調控。以黑龍江和內蒙古為例,來介紹下如何在FineReport中利用JavaScript自定義地圖標簽。

          新建地圖

          以區域地圖為例,新建表單,拖入地圖(新特性)組件,地圖邊界選擇區域地圖下的中國(省級):


          數據準備

          新建工作簿,添加數據集ds1,SELECT*FROM地圖1,選中圖表,選擇圖表屬性表-數據,如下圖所示:


          選擇圖表屬性表-樣式>系列,如下圖設置,邊框設為藍色:


          自定義JS顯示標簽

          選擇圖表屬性表-樣式>標簽,內容選擇自定義,JS如下:


          function(){ var points = this.points;
          var total = '<div style="width:100%;height:100%;">';
          if(this.name=="內蒙古自治區")
          {total += '<div align=center style="margin-top:30px"><span style="font-size:25px;color:'+FR.contentFormat(points[1].value, '')+'">' +FR.contentFormat(points[2].value, '#0.00')+'</span>'+this.name+'</div>';}
          else if(this.name=="黑龍江省")
          {total += '<div align=center style="margin-top:100px;"><span style="font-size:25px;color:'+FR.contentFormat(points[1].value, '')+'">'+ FR.contentFormat(points[2].value, '#0.00')+'</span>'+this.name+'</div>';}
          else{total += '<div align=center ><span style="font-size:25px;color:'+FR.contentFormat(points[1].value, '')+'">'+FR.contentFormat(points[2].value, '#0.00')+'</span>'+this.name+'</div>';}
          for(var i = 0, len = points.length-2; i < len; i++)
          {total += ('<div  align=center>'+FR.contentFormat(points[i].value, '#0.00')+'</div>');}
          total+='</div>'; return total;}

          div align=center style="margin-top當讀取名字為內蒙古自治區時候,我們進行margin顯示位置的調整,使其不顯示偏離

          FR.contentFormat(value, '#.##%')行數值格式自定義,后面的'#.##%'可以根據實際需求進行更改;

          this.points這個參數在地圖中使用時表示同一個區域上的不同的系列的點

          自定義JS顯示提示點

          選擇圖表屬性表-樣式>提示,內容選擇自定義,JS如下:


          function(){var points = this.points ;
          var total = '<div style="width:100%;
          background-color:#808080;color:white">';
          total +='<div align=left style="font-size:16px">'+this.name+'</div>';
          for(var i = 0, len = points.length-1; i < len; i++)
          {total +='<div align=left style="font-size:13px">●'+points[i].seriesName+':'+FR.contentFormat(points[i].value, '')+'</div>';}
          return total;}

          此處做一個簡單的循環,循環展示我們前端設置的參數,并對參數做單獨的處理,包括控制字體大小,以及顯示格式。

          保存與預覽

          調整后效果如下,標簽位置正確,提示采用了自定義格式:




          主站蜘蛛池模板: 平昌县| 蛟河市| 光泽县| 天台县| 冀州市| 赤水市| 旬邑县| 筠连县| 山西省| 阿坝县| 屏东县| 湘潭县| 屏山县| 内乡县| 重庆市| 卢湾区| 新蔡县| 木里| 天峻县| 乐山市| 静海县| 叙永县| 江孜县| 韶山市| 大埔县| 涪陵区| 乐安县| 大余县| 新邵县| 白城市| 三原县| 汤原县| 台北市| 贡嘎县| 宁化县| 瑞丽市| 岳阳县| 新野县| 永宁县| 库尔勒市| 化州市|