热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[D3]13.CleanerD3codewithselection.call()

selection.call()methodinD3canaidincodeorganizationandflexibilitybyeliminatingtheneedt

selection.call() method in D3 can aid in code organization and flexibility by eliminating the need to use chained method calls for every operation.

 

DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>title>
    <script src="../bower_components/underscore/underscore-min.js">script>
    <script src="../ventor/d3.min.js">script>
    <style type="text/css">

        body {
            padding-top: 50px;
            padding-left: 100px;

        }

        #chartArea {
            width: 400px;
            height: 300px;
            background-color: #CCC;
        }

        .bar {
            display: inline-block;
            width: 20px;
            height: 75px; /* Gets overriden by D3-assigned height below */
            margin-right: 2px;
            /* fill: teal; *//* SVG doesn't have background prop, use fill instead*/
            z-index: 99;
        }

        .bubble, .center {
            display: inline-block;
            fill: purple;
            fill-opacity: 0.5;
            stroke: black;
            stroke-weight: 1px;;
            z-index: 15;
        }

        .center {
            z-index: 10;
        }

        .active {
            fill: magenta;
            fill-opacity: 0.5;
            stroke-width: 3px;
        }

        .axis path, .axis line {
            fill: none;
            stroke: #000;
            stroke-width: 1px;
            shape-rendering: crispEdges;
        }

    style>
head>
<body>
<button onclick="update()">Updatebutton>
<section id="chartArea">section>
<script>

    function planTrasition(selection, duration, color){

        selection
                .transition()
                .duration(duration)
                .style('fill', color)
                .attr('cx', function(each_data, index) {
                    return xScale(each_data.x);
                })
                .attr('cy', function(each_data) {
                    return yScale(each_data.y);
                })
                .attr('r', function(each_data, i) {
                    return each_data.r;
                });
    }

    function stepTransition(selection) {

        selection.transition()
                .duration(600)
                .style('fill', "lightblue")
                .attr('cx', function(each_data, index) {
                    return xScale(each_data.x);
                })
                .transition()
                .duration(600)
                .attr('cy', function(each_data) {
                    return yScale(each_data.y);
                })
                .transition()
                .duration(600)
                .attr('r', function(each_data, i) {
                    return each_data.r;
                });
    }

    function newData(d){
        d.x = Math.round(Math.random() * 100);
        d.y = Math.round(Math.random() * 100);
        d.r = Math.round(5 + Math.random() * 10);
    }

    function update(){

        //Only the data which x <50 will get update
        svg.selectAll('circle')
                .filter(function(d) {
                    return d.x < 50;
                })
                .each( newData)
                .call(stepTransition);

        svg.selectAll('circle')
                .filter(function(d) {
                    return d.x >= 50;
                })
                .each( newData)
                .call(planTrasition, 2000, "red");
    }

    var dataset = _.map(_.range(30), function(num) {
                return {
                    x: Math.round(Math.random() * 100),
                    y: Math.round(Math.random() * 100),
                    r: Math.round(5 + Math.random() * 10)
                };
            }), //reandom generate 15 data from 1 to 50
            margin = {top: 20, right: 20, bottom: 40, left: 40},
            w = 400 - margin.left - margin.right,
            h = 300 - margin.top - margin.bottom;

    var svg = d3.select('#chartArea').append('svg')
            .attr('width', w + margin.left + margin.right)
            .attr('height', h + margin.top + margin.bottom)
            .append('g') //The last step is to add a G element which is a graphics container in SBG.
            .attr('transform', 'translate(' + margin.left + ', ' + margin.top + ')'); //Then offset that graphic element by our left and top margins.


    var yScale = d3.scale.linear()
            .domain([0, d3.max(dataset, function(d) {
                return d.y; //tell the max function just need to care about y prop
            })])
            .range([h, 0]);

    var yAxis = d3.svg.axis()
            .scale(yScale)
            .orient('left')
            .ticks(10)
            .innerTickSize(10)
            .outerTickSize(10)
            .tickPadding(10);
    svg.append('g')
            .attr('class', 'y axis')
            .attr('transform', 'translate(0,0)')
            .call(yAxis);

    var xScale = d3.scale.linear()
            .domain([0, 100])
            .range([0, w]);

    var xAxis = d3.svg.axis()
            .scale(xScale)
            .orient('bottom')
            .ticks(10)
            .innerTickSize(6)
            .outerTickSize(12)
            .tickPadding(12);

    svg.append('g')
            .attr('class', 'x axis')
            .attr('transform', 'translate(0, ' + h + ')')
            .call(xAxis);

    svg.selectAll('circle')
            .data(dataset)
            .enter()
            .append('circle')// svg doesn't have div, use rect instead
            .attr('class', "bubble")
            .attr('cx', function(each_data, index) {
                return xScale(each_data.x);
            })
            .attr('cy', function(each_data) {
                return yScale(each_data.y);
            })
            .attr('r', function(each_data, i) {
                return each_data.r;
            })
            .on('mouseover', function() {
                d3.select(this).classed('active', true)
            })
            .on('mouseleave', function() {
                d3.select(this).classed('active', false)
            })
            .on('mousedown', function(d) {
                var p_cx = d.x, p_cy = d.y, p_r = d.r;
                d3.select(this).transition().duration(500).attr('r', d.r * 1.5);
                svg.append('circle')
                        .attr('class', "center")
                        .attr('cx', function() {
                            return xScale(p_cx);
                        })
                        .attr('cy', function() {
                            return yScale(p_cy);
                        })
                        .attr('r', function() {
                            return p_r / 4;
                        })
                        .style('fill', 'red');
            })
            .on('mouseup', function(d) {

                d3.select(this).transition().duration(250).delay(100).attr('r', d.r)
            });
script>
body>
html>

 

 


推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • Givenasinglylinkedlist,returnarandomnode'svaluefromthelinkedlist.Eachnodemusthavethe s ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • Android自定义控件绘图篇之Paint函数大汇总
    本文介绍了Android自定义控件绘图篇中的Paint函数大汇总,包括重置画笔、设置颜色、设置透明度、设置样式、设置宽度、设置抗锯齿等功能。通过学习这些函数,可以更好地掌握Paint的用法。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 花瓣|目标值_Compose 动画边学边做夏日彩虹
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Compose动画边学边做-夏日彩虹相关的知识,希望对你有一定的参考价值。引言Comp ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • 颜色迁移(reinhard VS welsh)
    不要谈什么天分,运气,你需要的是一个截稿日,以及一个不交稿就能打爆你狗头的人,然后你就会被自己的才华吓到。------ ... [详细]
author-avatar
liuleyi
这个家伙很懒,什么也没留下!
Tags | 热门标签
RankList | 热门文章
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有