d3之散点图封装(动画呈现)

效果图:


我的影片.gif
  1. html:
<div style="position:absolute;width:100%;height: 100%;">
  <div id="mychart" style="float:left;width:100%;height: 100%;"></div>
</div>

2.数据准备:

var dataset = [
                ['白酒',175,1477],['饼干',249,2258],['炒货',261,2329],
                ['除污类',230,2775],['果酒',5,2523],['护理用品',204,1886],
                ['家用杂品',255,2333],['洁面护肤',267,1392],['进口食品',164,1551],
                ['毛巾',68,1655],['面点类',35,2310],['面类',11,1903],
                ['沐浴',170,1893],['啤酒',190,1898],['其他',212,1248],
                ['肉及水产',179,1166],['食材',213,1497],['食品杂货',180,2439],
                ['蔬菜类',10,2389],['糖果',28,1417],['调料类',299,2179],
                ['文具期刊',203,1785],['洗发',132,1545],['洗衣类',187,1850],
                ['香烟',234,1968],['小五金',208,1320],['休闲小食',188,1465],
                ['牙膏牙刷',93,1492],['饮料',85,1943],['纸质品',127,2336]
            ];
            //[ ['白酒','饼干','炒货'...],[175,249,261..],[1477,2258,2329...] ]
var dataset_new = d3.transpose(dataset);            
var dlabel = dataset_new[0];
var xdata = dataset_new[1];
var ydata = dataset_new[2];
            
var _colorscale = d3.scaleQuantize()
                   .domain([1000,3000])
                   .range(['red','yellow','orange','green']);

3.散点图方法封装

function drawscatter(divname,ydata,xdata,dlabel){
                
                var _swidth = $("#"+divname).width();
                var _sheight = $("#"+divname).height();
                var _margin = {top:10,left:30,right:10,bottom:30};
                var _titleHeight = 50;
                //得到绘图区的高度和宽度
                var _chartHeight = _sheight - _margin.top - _margin.bottom - _titleHeight;
                var _chartWidth = _swidth - _margin.left - _margin.right;
                
                //核心绘图区的边距
                var _chartmargin  =  {top:20,left:20,right:20,bottom:20};
                
                //核心绘图区的高度和宽度
                var _yaxisHeight = _chartHeight - _chartmargin.top - _chartmargin.bottom;
                var _xaxisWidth = _chartWidth - _chartmargin.left - _chartmargin.right;
                
                var _padding = 0.5;
                
                var _svg = d3.select("#"+divname)
                        .append("svg")
                        .attr("width",_swidth)
                        .attr("height",_sheight);
                        
                        
                var _glevel1 = _svg.append("g")
                                    .attr("transform","translate("+_margin.left +","+_margin.top+")");
                
                var _glevel2_title = _glevel1.append("g");
                
                var _glevel2_chart = _glevel1.append("g")
                                        .attr("transform","translate(0,"+_titleHeight+")");
                
                var _gleve3_yaxis = _glevel2_chart.append("g")
                                .attr("id","gyaxis")
                                .attr("transform","translate("+_chartmargin.left+","+_chartmargin.top+")");
                
                
                var _gleve3_xaxis = _glevel2_chart.append("g")
                                .attr("id","gxaxis")
                                .attr("transform","translate("+_chartmargin.left+","+(_chartHeight - _chartmargin.bottom)+")");
            
                var _gleve3_content = _glevel2_chart.append("g")
                                .attr("id","chartcontent")
                                .attr("transform","translate("+_chartmargin.left+","+_chartmargin.top+")");
                
                
                //定义Y轴比例尺
                var _yscale = d3.scaleLinear()
                                   .domain( [0 , d3.max(ydata) ] ).nice()
                                   .range([_yaxisHeight,0])
                                   .clamp(true) ;
                //定义Y轴坐标轴,使用前面定义的比例尺
                var _yaxis = d3.axisLeft()
                                .scale(_yscale)
                                .ticks(5);
                
                _yaxis(_gleve3_yaxis);          
                
                //定义X轴比例尺
                var _xscale = d3.scaleLinear()
                               .domain([0,d3.max(xdata)])
                               .range([0,_xaxisWidth]);
                //定义X轴坐标轴
                var _xaxis = d3.axisBottom()
                                .scale(_xscale);
                
                _xaxis(_gleve3_xaxis);
                
                _gleve3_content.append("g")
                        .selectAll("circle")
                        .data(dlabel)
                        .enter()
                        .append("circle")
                        .attr("cx",0)
                        .attr("cy",_yaxisHeight)
                        .attr("r","0")
                        .style("fill",function(d,i){
                            return _colorscale(ydata[i]);
                        })
                        .transition()
                        .duration(5000)
                        .ease(d3.easeBounce)
                        .attr("cx",function(d,i){
                            return   _xscale(xdata[i]);
                        })
                        .attr("cy",function(d,i){
                            return _yscale(ydata[i]) ;
                        })
                        .attr("r","10");
//              
                _gleve3_content.append("g")
                        .selectAll("text")
                        .data(dlabel)
                        .enter()
                        .append("text")
                        .attr("x",0)
                        .attr("y",_yaxisHeight)
                        .attr("dx",'10')
                        .attr("dy","0.5em")
                        .style("fill",function(d,i){
                            return _colorscale(ydata[i]);
                        })
                        .transition()
                        .duration(5000)
                        .ease(d3.easeBounce)
                        .attr("x",function(d,i){
                            return _xscale(xdata[i]);
                        })
                        .attr("y",function(d,i){
                            return _yscale(ydata[i]);
                        })
                        .filter(function(d,i){
                            return ydata[i]>2500;
                        })
                        .text(function(d,i){
                            return d;
                        });
                        
                        
                drawYaxisGrid("gyaxis",_xaxisWidth,"#ff1");
                drawXaxisGrid("gxaxis",_yaxisHeight,"#ff1");
            }
//给Y轴添加分割线
function drawYaxisGrid(divname,xwidth,color){
                d3.select("#"+divname)
                    .selectAll("g")
                    .append("line")
                    .attr("x1",0)
                    .attr("y1",0)
                    .attr("x2",xwidth)
                    .attr("y2",0)
                    .attr("stroke",color)
                    .attr("stroke-width","0.5");
            }
            
//给X轴添加分割线
function drawXaxisGrid(divname,yheight,color){
                d3.select("#"+divname)
                    .selectAll("g")
                    .append("line")
                    .attr("x1",0)
                    .attr("y1",0)
                    .attr("x2",0)
                    .attr("y2",-1*yheight)
                    .attr("stroke",color)
                    .attr("stroke-width","0.5");
            }

4.调用方法:

drawscatter("mychart",ydata,xdata,dlabel);
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,096评论 1 32
  • 一、简历准备 1、个人技能 (1)自定义控件、UI设计、常用动画特效 自定义控件 ①为什么要自定义控件? Andr...
    lucas777阅读 5,200评论 2 54
  • 迎来了这一场盛典的落幕 团队的文化也是在这一刻有了深层次的合作 而这一刻,我却久久未眠,思量着失之交臂的总结篇.....
    斯丹钰阅读 197评论 2 1
  • 汕头是鲜,潮州是古。 住在牌坊街周边小巷里的民宿院子。我想到扬州老巷当中,盐商大宅和现在的普通人家交错毗邻——潮州...
    小冠没道理阅读 717评论 0 0
  • 之前提过,很多朋友问我为什么对孩子那么有耐心,我答:“因为我看他就是哪都好啊!” 朋友问题又来了:你怎么就看他哪都...
    李涵悦阅读 481评论 1 9