D3.js - Guia rápido

A visualização de dados é a apresentação de dados em formato pictórico ou gráfico. O principal objetivo da visualização de dados é comunicar informações de maneira clara e eficiente por meio de gráficos estatísticos, plotagens e gráficos de informações.

A visualização de dados nos ajuda a comunicar nossos insights de forma rápida e eficaz. Qualquer tipo de dado, que é representado por uma visualização, permite ao usuário comparar os dados, gerar relatórios analíticos, entender padrões e assim auxiliá-los na tomada de decisão. As visualizações de dados podem ser interativas, para que os usuários analisem dados específicos no gráfico. Bem, as visualizações de dados podem ser desenvolvidas e integradas em sites comuns e até mesmo em aplicativos móveis usando diferentes estruturas JavaScript.

O que é D3.js?

D3.js é uma biblioteca JavaScript usada para criar visualizações interativas no navegador. A biblioteca D3.js nos permite manipular elementos de uma página da web no contexto de um conjunto de dados. Esses elementos podem serHTML, SVG, ou Canvas elementse podem ser introduzidos, removidos ou editados de acordo com o conteúdo do conjunto de dados. É uma biblioteca para manipular os objetos DOM. O D3.js pode ser uma ajuda valiosa na exploração de dados, pois dá a você controle sobre a representação dos dados e permite adicionar interatividade.

Por que precisamos do D3.js?

D3.js é um dos frameworks principais quando comparado a outras bibliotecas. Isso porque funciona na web e suas visualizações de dados são por excelência. Outra razão pela qual funcionou tão bem é devido à sua flexibilidade. Uma vez que funciona perfeitamente com as tecnologias da web existentes e pode manipular qualquer parte do modelo de objeto do documento, é tão flexível quanto oClient Side Web Technology Stack(HTML, CSS e SVG). Tem um grande apoio da comunidade e é mais fácil de aprender.

Recursos do D3.js

D3.js é uma das melhores estruturas de visualização de dados e pode ser usado para gerar visualizações simples e complexas, juntamente com a interação do usuário e efeitos de transição. Algumas de suas características mais importantes estão listadas abaixo -

  • Extremamente flexível.
  • Fácil de usar e rápido.
  • Suporta grandes conjuntos de dados.
  • Programação declarativa.
  • Reutilização de código.
  • Possui ampla variedade de funções de geração de curvas.
  • Associa dados a um elemento ou grupo de elementos na página html.

Benefícios do D3.js

D3.js é um projeto de código aberto e funciona sem nenhum plugin. Requer muito menos código e apresenta os seguintes benefícios -

  • Excelente visualização de dados.

  • É modular. Você pode baixar um pequeno pedaço de D3.js, que você deseja usar. Não há necessidade de carregar toda a biblioteca sempre.

  • Fácil de construir um componente gráfico.

  • Manipulação DOM.

No próximo capítulo, vamos entender como instalar o D3.js em nosso sistema.

Neste capítulo, aprenderemos como configurar o ambiente de desenvolvimento D3.js. Antes de começar, precisamos dos seguintes componentes -

  • Biblioteca D3.js
  • Editor
  • Navegador da web
  • servidor web

Vamos seguir as etapas uma a uma em detalhes.

Biblioteca D3.js

Precisamos incluir a biblioteca D3.js em sua página HTML para usar o D3.js para criar a visualização de dados. Podemos fazer isso das duas maneiras a seguir -

  • Inclua a biblioteca D3.js da pasta do seu projeto.
  • Inclui a biblioteca D3.js da CDN (Content Delivery Network).

Baixe a biblioteca D3.js

D3.js é uma biblioteca de código aberto e o código-fonte da biblioteca está disponível gratuitamente na web em https://d3js.org/local na rede Internet. Visite o site do D3.js e baixe a versão mais recente do D3.js (d3.zip). A partir de agora, a última versão é 4.6.0.

Após a conclusão do download, descompacte o arquivo e procure d3.min.js. Esta é a versão reduzida do código-fonte D3.js. Copie o arquivo d3.min.js e cole-o na pasta raiz do seu projeto ou em qualquer outra pasta, onde deseja manter todos os arquivos da biblioteca. Inclua o arquivo d3.min.js em sua página HTML, conforme mostrado abaixo.

Example - Vamos considerar o seguinte exemplo.

<!DOCTYPE html>
<html lang = "en">
   <head>
      <script src = "/path/to/d3.min.js"></script>
   </head>

   <body>
      <script>
         // write your d3 code here.. 
      </script>
   </body>
</html>

D3.js é um código JavaScript, então devemos escrever todo o nosso código D3 dentro da tag “script”. Podemos precisar manipular os elementos DOM existentes, portanto, é aconselhável escrever o código D3 antes do final da tag “body”.

Incluir Biblioteca D3 do CDN

Podemos usar a biblioteca D3.js vinculando-a diretamente à nossa página HTML da Content Delivery Network (CDN). CDN é uma rede de servidores onde os arquivos são hospedados e entregues a um usuário com base em sua localização geográfica. Se usarmos o CDN, não precisamos baixar o código-fonte.

Incluir a biblioteca D3.js usando o URL CDN https://d3js.org/d3.v4.min.js em nossa página conforme mostrado abaixo.

Example - Vamos considerar o seguinte exemplo.

<!DOCTYPE html>
<html lang = "en">
   <head>
      <script src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <script>
         // write your d3 code here.. 
      </script>
   </body>
</html>

Editor D3.js

Precisamos de um editor para começar a escrever seu código. Existem alguns grandes IDEs (Ambiente de Desenvolvimento Integrado) com suporte para JavaScript como -

  • Código Visual Studio
  • WebStorm
  • Eclipse
  • Sublime Texto

Esses IDEs fornecem autocompletar de código inteligente e também oferecem suporte a algumas das estruturas JavaScript modernas. Se você não tiver um IDE sofisticado, pode sempre usar um editor básico como o Notepad, VI, etc.

Navegador da web

D3.js funciona em todos os navegadores, exceto IE8 e inferior.

Servidor web

A maioria dos navegadores fornece arquivos HTML locais diretamente do sistema de arquivos local. No entanto, existem certas restrições quando se trata de carregar arquivos de dados externos. Nos últimos capítulos deste tutorial, estaremos carregando dados de arquivos externos comoCSV e JSON. Portanto, será mais fácil para nós, se configurarmos o servidor web desde o início.

Você pode usar qualquer servidor web com o qual se sinta confortável - por exemplo, IIS, Apache, etc.

Visualizando sua página

Na maioria dos casos, podemos apenas abrir seu arquivo HTML em um navegador da web para visualizá-lo. No entanto, ao carregar fontes de dados externas, é mais confiável executar um servidor da web local e visualizar sua página a partir do servidor(http://localhost:8080).

D3.js é uma biblioteca JavaScript de código aberto para -

  • Manipulação baseada em dados do Document Object Model (DOM).
  • Trabalhando com dados e formas.
  • Disposição de elementos visuais para dados lineares, hierárquicos, de rede e geográficos.
  • Habilitando transições suaves entre os estados da interface do usuário (IU).
  • Habilitando a interação efetiva do usuário.

Padrões da Web

Antes de começarmos a usar D3.js para criar visualizações, precisamos nos familiarizar com os padrões da web. Os seguintes padrões da web são amplamente usados ​​em D3.js.

  • HyperText Markup Language (HTML)
  • Document Object Model (DOM)
  • Cascading Style Sheets (CSS)
  • Gráficos vetoriais escaláveis ​​(SVG)
  • JavaScript

Vamos examinar cada um desses padrões da web em detalhes, um por um.

HyperText Markup Language (HTML)

Como sabemos, o HTML é usado para estruturar o conteúdo da página da web. Ele é armazenado em um arquivo de texto com a extensão “.html”.

Example - Um exemplo típico de HTML básico se parece com isto

<!DOCTYPE html>
<html lang = "en">
   <head>
      <meta charset = "UTF-8">
      <title></title>
   </head>

   <body>
   </body>
</html>

Document Object Model (DOM)

Quando uma página HTML é carregada por um navegador, ela é convertida em uma estrutura hierárquica. Cada tag em HTML é convertida em um elemento / objeto no DOM com uma hierarquia pai-filho. Isso torna nosso HTML mais logicamente estruturado. Depois que o DOM é formado, torna-se mais fácil manipular (adicionar / modificar / remover) os elementos da página.

Deixe-nos entender o DOM usando o seguinte documento HTML -

<!DOCTYPE html>
<html lang = "en">
   <head>
      <title>My Document</title>
   </head>

   <body>
      <div>
         <h1>Greeting</h1>
         <p>Hello World!</p>
      </div>
   </body>
</html>

O modelo de objeto de documento do documento HTML acima é o seguinte,

Cascading Style Sheets (CSS)

Enquanto o HTML fornece uma estrutura para a página da web, os estilos CSS tornam a página da web mais agradável de se olhar. CSS é umStyle Sheet Languageusado para descrever a apresentação de um documento escrito em HTML ou XML (incluindo dialetos XML como SVG ou XHTML). CSS descreve como os elementos devem ser renderizados em uma página da web.

Gráficos vetoriais escaláveis ​​(SVG)

SVG é uma forma de renderizar imagens na página da web. SVG não é uma imagem direta, mas apenas uma maneira de criar imagens usando texto. Como o próprio nome sugere, é umScalable Vector. Ele se dimensiona de acordo com o tamanho do navegador, portanto, redimensioná-lo não distorce a imagem. Todos os navegadores são compatíveis com SVG, exceto IE 8 e anteriores. As visualizações de dados são representações visuais e é conveniente usar SVG para renderizar visualizações usando o D3.js.

Pense no SVG como uma tela na qual podemos pintar diferentes formas. Então, para começar, vamos criar uma tag SVG -

<svg width = "500" height = "500"></<svg>

A medida padrão para SVG é pixels, portanto, não precisamos especificar se nossa unidade é pixel. Agora, se quisermos desenhar um retângulo, podemos desenhá-lo usando o código abaixo -

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200"></rect>
</svg>

Podemos desenhar outras formas em SVG, como - Linha, Círculo, Elipse, Texto e Caminho.

Assim como estilizar elementos HTML, estilizar elementos SVG é simples. Vamos definir a cor de fundo do retângulo como amarelo. Para isso, precisamos adicionar um atributo “fill” e especificar o valor como amarelo conforme mostrado abaixo -

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200" fill = "yellow"></rect>
</svg>

JavaScript

JavaScript é uma linguagem de script do lado do cliente com tipagem flexível que é executada no navegador do usuário. JavaScript interage com elementos HTML (elementos DOM) para tornar a interface do usuário da web interativa. JavaScript implementa oECMAScript Standards, que inclui recursos centrais baseados nas especificações ECMA-262, bem como outros recursos, que não são baseados nos padrões ECMAScript. Conhecimento de JavaScript é um pré-requisito para D3.js.

Seleções é um dos conceitos básicos em D3.js. É baseado em seletores CSS. Ele nos permite selecionar um ou mais elementos em uma página da web. Além disso, permite-nos modificar, acrescentar ou remover elementos em relação ao conjunto de dados predefinido. Neste capítulo, veremos como usar seleções para criar visualizações de dados.

D3.js ajuda a selecionar elementos da página HTML usando os dois métodos a seguir -

  • select()- Seleciona apenas um elemento DOM correspondendo ao seletor CSS fornecido. Se houver mais de um elemento para o seletor CSS fornecido, ele seleciona apenas o primeiro.

  • selectAll()- Seleciona todos os elementos DOM correspondendo ao seletor CSS fornecido. Se você está familiarizado com a seleção de elementos com jQuery, os seletores D3.js são quase os mesmos.

Vamos examinar cada um dos métodos em detalhes.

O método select ()

O método select () seleciona o elemento HTML com base nos seletores CSS. Nos seletores CSS, você pode definir e acessar elementos HTML das três maneiras a seguir -

  • Tag de um elemento HTML (por exemplo, div, h1, p, span, etc.,)
  • Nome da classe de um elemento HTML
  • ID de um elemento HTML

Vamos vê-lo em ação com exemplos.

Seleção por Tag

Você pode selecionar elementos HTML usando seu TAG. A seguinte sintaxe é usada para selecionar os elementos da tag “div”,

d3.select(“div”)

Example - Crie uma página “select_by_tag.html” e adicione as seguintes alterações,

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div>
         Hello World!    
      </div>
      
      <script>
         alert(d3.select("div").text());
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela -

Seleção por nome de classe

Elementos HTML estilizados usando classes CSS podem ser selecionados usando a seguinte sintaxe.

d3.select(“.<class name>”)

Crie uma página da web “select_by_class.html” e adicione as seguintes alterações -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         alert(d3.select(".myclass").text());
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela -

Seleção por ID

Cada elemento em uma página HTML deve ter um ID exclusivo. Podemos usar este ID exclusivo de um elemento para acessá-lo usando o método select () conforme especificado abaixo.

d3.select(“#<id of an element>”)

Crie uma página da web “select_by_id.html” e adicione as seguintes alterações.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div id = "hello">
         Hello World!
      </div>
      
      <script>
         alert(d3.select("#hello").text());
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela.

Adicionando Elementos DOM

A seleção D3.js fornece o append() e a text()métodos para acrescentar novos elementos aos documentos HTML existentes. Esta seção explica como adicionar elementos DOM em detalhes.

O método append ()

O método append () anexa um novo elemento como o último filho do elemento na seleção atual. Este método também pode modificar o estilo dos elementos, seus atributos, propriedades, HTML e conteúdo de texto.

Crie uma página da web “select_and_append.html” e adicione as seguintes alterações -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select("div.myclass").append("span");
      </script>
   </body>
</html>

Solicitando a página da web por meio do navegador, você pode ver a seguinte saída na tela,

Aqui, o método append () adiciona um novo intervalo de tag dentro da tag div, conforme mostrado abaixo -

<div class = "myclass">
   Hello World!<span></span>
</div>

O Método text ()

O método text () é usado para definir o conteúdo dos elementos selecionados / anexados. Vamos mudar o exemplo acima e adicionar o método text () conforme mostrado abaixo.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select("div.myclass").append("span").text("from D3.js");
      </script>
   </body>
</html>

Agora atualize a página da web e você verá a seguinte resposta.

Aqui, o script acima executa uma operação de encadeamento. D3.js inteligentemente emprega uma técnica chamada dechain syntax, que você pode reconhecer de jQuery. Encadeando métodos junto com pontos, você pode executar várias ações em uma única linha de código. É rápido e fácil. O mesmo script também pode acessar sem sintaxe de cadeia, conforme mostrado abaixo.

var body = d3.select("div.myclass");
var span = body.append("span");
span.text("from D3.js");

Modificando Elementos

D3.js fornece vários métodos, html(), attr() e style()para modificar o conteúdo e o estilo dos elementos selecionados. Vamos ver como usar métodos de modificação neste capítulo.

O método html ()

O método html () é usado para definir o conteúdo html dos elementos selecionados / anexados.

Crie uma página da web “select_and_add_html.html” e adicione o seguinte código.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").html("Hello World! <span>from D3.js</span>");
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela.

O método attr ()

O método attr () é usado para adicionar ou atualizar o atributo dos elementos selecionados. Crie uma página da web “select_and_modify.html” e adicione o seguinte código.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").attr("style", "color: red");
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela.

O método style ()

O método style () é usado para definir a propriedade de estilo dos elementos selecionados. Crie uma página da web “select_and_style.html” e adicione o seguinte código.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").style("color", "red");
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela.

O método classed ()

O método classed () é usado exclusivamente para definir o atributo “class” de um elemento HTML. Desde então, um único elemento HTML pode ter várias classes; precisamos ter cuidado ao atribuir uma classe a um elemento HTML. Este método sabe como lidar com uma ou mais classes em um elemento e terá um bom desempenho.

  • Add class- Para adicionar uma classe, o segundo parâmetro do método classificado deve ser definido como verdadeiro. É definido abaixo -

d3.select(".myclass").classed("myanotherclass", true);
  • Remove class- Para remover uma classe, o segundo parâmetro do método classificado deve ser definido como falso. É definido abaixo -

d3.select(".myclass").classed("myanotherclass", false);
  • Check class- Para verificar a existência de uma classe, basta omitir o segundo parâmetro e passar o nome da classe que você está consultando. Isso retornará verdadeiro, se existir, falso, se não existir.

d3.select(".myclass").classed("myanotherclass");

Isso retornará verdadeiro, se algum elemento da seleção tiver a classe. Usard3.select para seleção de elemento único.

  • Toggle class - Para virar uma classe para o estado oposto - remova-a se já existir, adicione-a se ainda não existir - você pode fazer uma das seguintes opções.

    Para um único elemento, o código pode ter a seguinte aparência -

var element = d3.select(".myclass")
element.classed("myanotherclass", !oneBar.classed("myanotherclass"));

O método selectAll ()

O método selectAll () é usado para selecionar vários elementos no documento HTML. O método select seleciona o primeiro elemento, mas o método selectAll seleciona todos os elementos que correspondem à sequência de seleção específica. Caso a seleção não corresponda a nenhum, então ele retorna uma seleção vazia. Podemos encadear todos os métodos de modificação anexados,append(), html(), text(), attr(), style(), classed(),etc., também no método selectAll (). Nesse caso, os métodos afetarão todos os elementos correspondentes. Deixe-nos entender criando uma nova página da web “select_multiple.html” e adicionando o seguinte script -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h2 class = "myclass">Message</h2>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.selectAll(".myclass").attr("style", "color: red");
      </script>
   </body>
</html>

Ao solicitar a página da web por meio do navegador, você verá a seguinte saída na tela.

Aqui, o método attr () se aplica a ambos div e h2 tag e a cor do texto em ambas as tags muda para vermelho.

A junção de dados é outro conceito importante em D3.js. Ele funciona junto com as seleções e nos permite manipular o documento HTML em relação ao nosso conjunto de dados (uma série de valores numéricos). Por padrão, D3.js dá ao conjunto de dados a prioridade mais alta em seus métodos e cada item no conjunto de dados corresponde a um elemento HTML. Este capítulo explica as junções de dados em detalhes.

O que é uma junção de dados?

A junção de dados nos permite injetar, modificar e remover elementos (elemento HTML, bem como elementos SVG incorporados) com base no conjunto de dados no documento HTML existente. Por padrão, cada item de dados no conjunto de dados corresponde a um elemento (gráfico) no documento.

Conforme o conjunto de dados muda, o elemento correspondente também pode ser facilmente manipulado. A junção de dados cria um relacionamento próximo entre nossos dados e os elementos gráficos do documento. A junção de dados torna a manipulação dos elementos com base no conjunto de dados um processo muito simples e fácil.

Como funciona a junção de dados?

O objetivo principal da junção de dados é mapear os elementos do documento existente com o conjunto de dados fornecido. Ele cria uma representação virtual do documento em relação ao conjunto de dados fornecido e fornece métodos para trabalhar com a representação virtual. Vamos considerar um conjunto de dados simples, conforme mostrado abaixo.

[10, 20, 30, 25, 15]

O conjunto de dados possui cinco itens e, portanto, pode ser mapeado para cinco elementos do documento. Vamos mapear para oli elemento do seguinte documento usando o método selectAll () do seletor e o método data () da junção de dados.

HTML

<ul id = "list">
   <li><li>
   <li></li>
</ul>

Código D3.js

d3.select("#list").selectAll("li").data([10, 20, 30, 25, 15]);

Agora, existem cinco elementos virtuais no documento. Os primeiros dois elementos virtuais são os doisli elemento definido no documento conforme mostrado abaixo.

1. li - 10
2. li - 20

Podemos usar todos os métodos de modificação de elementos do seletor, como attr(), style(), text(), etc., para os dois primeiros li como mostrado abaixo.

d3.select("#list").selectAll("li")
   .data([10, 20, 30, 25, 15])
   .text(function(d) { return d; });

A função no método text () é usada para obter o lielementos mapeados de dados. Aqui,d representam 10 para o primeiro li elemento e 20 para o segundo li elemento.

Os próximos três elementos podem ser mapeados para quaisquer elementos e isso pode ser feito usando o método enter () da junção de dados e o método append () do seletor. O método enter () dá acesso aos dados restantes (que não são mapeados para os elementos existentes) e o método append () é usado para criar um novo elemento a partir dos dados correspondentes. Vamos criarlipara os demais itens de dados também. O mapa de dados é o seguinte -

3. li - 30
4. li - 25
5. li - 15

O código para criar um novo elemento a li é o seguinte -

d3.select("#list").selectAll("li")
   .data([10, 20, 30, 25, 15])
   .text(function(d) { return "This is pre-existing element and the value is " + d; })
   .enter()
   .append("li")
   .text(function(d) 
      { return "This is dynamically created element and the value is " + d; });

A junção de dados fornece outro método chamado de exit() method para processar os itens de dados removidos dinamicamente do conjunto de dados, conforme mostrado abaixo.

d3.selectAll("li")
   .data([10, 20, 30, 15])
   .exit()
   .remove()

Aqui, removemos o quarto item do conjunto de dados e seu li correspondente usando os métodos exit () e remove ().

O código completo é o seguinte -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         body { font-family: Arial; }
      </style>
   </head>

   <body>
      <ul id = "list">
         <li></li>
         <li></li>
      </ul>
        
      <input type = "button" name = "remove" value = "Remove fourth value" 
         onclick = "javascript:remove()" />
      
      <script>
         d3.select("#list").selectAll("li")
            .data([10, 20, 30, 25, 15])
            .text(function(d) 
               { return "This is pre-existing element and the value is " + d; })
            .enter()
            .append("li")
            .text(function(d) 
               { return "This is dynamically created element and the value is " + d; });
             
         function remove() {
            d3.selectAll("li")
            .data([10, 20, 30, 15])
            .exit()
            .remove()
         }
      </script>
   </body>
</html>

O resultado do código acima será o seguinte -

D3 contém uma coleção de módulos. Você pode usar cada módulo de forma independente ou uma coleção de módulos juntos para realizar operações. Este capítulo explica em detalhes sobre a API Array.

O que é uma matriz?

Um Array contém uma coleção sequencial de tamanho fixo de elementos do mesmo tipo. Uma matriz é usada para armazenar uma coleção de dados, mas geralmente é mais útil pensar em uma matriz como uma coleção de variáveis ​​do mesmo tipo.

Configurando API

Você pode configurar facilmente a API usando o script abaixo.

<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<body>
   <script>
   </script>
</body>

Métodos de API de estatísticas de matriz

A seguir estão alguns dos métodos de API de estatísticas de matriz mais importantes.

  • d3.min(array)
  • d3.max(array)
  • d3.extent(array)
  • d3.sum(array)
  • d3.mean(array)
  • d3.quantile(array)
  • d3.variance(array)
  • d3.deviation(array)

Vamos discutir cada um deles em detalhes.

d3.min (matriz)

Ele retorna o valor mínimo na matriz fornecida usando a ordem natural.

Example - Considere o seguinte script.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.min(data));
</script>

Result - O script acima retorna o valor mínimo na matriz 20 em seu console.

d3.max (matriz)

Ele retorna o valor máximo em uma determinada matriz.

Example - Considere o seguinte script.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.max(data));
</script>

Result - O script acima retorna o valor máximo na matriz (100) em seu console.

d3.extent (array)

Ele retorna os valores mínimo e máximo na matriz fornecida.

Example - Considere o seguinte script.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.extent(data));
</script>

Result - O script acima retorna um valor de extensão [20,100].

d3.sum (matriz)

Ele retorna a soma da matriz de números fornecida. Se a matriz estiver vazia, ele retorna 0.

Example - Considere o seguinte abaixo.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.sum(data));
</script>

Result - O script acima retorna o valor da soma 300.

d3.mean (matriz)

Ele retorna a média da matriz de números fornecida.

Example - Considere o seguinte abaixo.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.mean(data));
</script>

Result - O script acima retorna o valor médio como 60. Da mesma forma, você pode verificar o valor mediano.

d3.quantile (array)

Ele retorna o quantil p da matriz classificada de números fornecida, onde p é um número no intervalo [0, 1]. Por exemplo, a mediana pode ser calculada usando p = 0,5, o primeiro quartil em p = 0,25 e o terceiro quartil em p = 0,75. Esta implementação usa o método R-7, a linguagem de programação R padrão e o Excel.

Example - Considere o seguinte exemplo.

var data = [20, 40, 60, 80, 100];
d3.quantile(data, 0); // output is 20
d3.quantile(data, 0.5); // output is 60
d3.quantile(data, 1); // output is 100

Da mesma forma, você pode verificar outros valores.

d3.variance (array)

Ele retorna a variância da matriz de números fornecida.

Example - Considere o seguinte script.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.variance(data));
</script>

Result - O script acima retorna o valor da variação como 1000.

d3.deviation (array)

Ele retorna o desvio padrão da matriz fornecida. Se a matriz tiver menos de dois valores, ela retorna como indefinida.

Example - Considere o seguinte abaixo.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.deviation(data));
</script>

Result - O script acima retorna o valor de desvio como 31.622776601683793.

Example- Vamos executar todos os métodos da API Array discutidos acima usando o seguinte script. Crie uma página da web “array.html” e adicione as seguintes alterações a ela.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 array API</h3>
      <script>
         var data = [20,40,60,80,100];
         console.log(d3.min(data));  
         console.log(d3.max(data));
         console.log(d3.extent(data));
         console.log(d3.sum(data));
         console.log(d3.mean(data));
         console.log(d3.quantile(data,0.5));
         console.log(d3.variance(data));
         console.log(d3.deviation(data));
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta.

Métodos da API Array Search

A seguir estão alguns métodos importantes da API de pesquisa de Array.

  • d3.scan(array)
  • d3.ascendente (a, b)

Vamos entender ambos em detalhes.

d3.scan (matriz)

Este método é usado para realizar uma varredura linear da matriz especificada. Ele retorna o índice do menor elemento para o comparador especificado. Um exemplo simples é definido abaixo.

Example -

var array = [{one: 1}, {one: 10}];
console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // output is 0
console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // output is 1

d3.ascendente (a, b)

Este método é usado para executar a função de comparador. Pode ser implementado como -

function ascending(a, b) {
   return a < b ? -1 : a > b ? 1 : a > =  b ? 0 : NaN;
}

Se nenhuma função de comparador for especificada para o método de classificação integrado, a ordem padrão é alfabética. A função acima retorna -1, se a for menor que b, ou 1, se a for maior que b, ou 0.

Da mesma forma, você pode executar o método descendente (a, b). Ele retorna -1, se a for maior que b, ou 1, se a for menor que b, ou 0. Esta função executa a ordem natural reversa.

Example -

Crie uma página da web array_search.html e adicione as seguintes alterações a ele.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 array API</h3>
      <script>
         var array = [{one: 1}, {one: 10}];
         console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // 0
         console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // 1
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos o seguinte resultado.

API Array Transformations

A seguir estão alguns dos métodos de API de transformações de array mais proeminentes.

  • d3.cross (a, b [, redutor])
  • d3.merge(arrays)
  • d3.pairs (array [, redutor])
  • d3.permute (matriz, índices)
  • d3.zip(arrays)

Vamos entender cada um deles em detalhes.

d3.cross (a, b [, redutor])

Este método é usado para retornar o produto cartesiano das duas matrizes a e b fornecidas. Um exemplo simples é definido abaixo.

d3.cross([10, 20], ["a", "b"]); // output is [[10, "a"], [10, "b"], [20, "a"], [20, "b"]]

d3.merge (arrays)

Este método é usado para mesclar as matrizes e é definido a seguir.

d3.merge([[10], [20]]); // output is [10, 20]

d3.pairs (array [, redutor])

Este método é usado para emparelhar elementos da matriz e é definido a seguir.

d3.pairs([10, 20, 30, 40]); // output is [[10, 20], [20, 30], [30, 40]]

d3.permute (matriz, índices)

Este método é usado para realizar a permutação da matriz e índices especificados. Você também pode executar os valores de um objeto em uma matriz. Isso é explicado a seguir.

var object = {fruit:"mango", color: "yellow"},
   fields = ["fruit", "color"];
d3.permute(object, fields); // output is "mango" "yellow"

d3.zip (matrizes)

Este método é usado para retornar uma matriz de matrizes. Se as matrizes contiverem apenas uma única matriz, a matriz retornada conterá matrizes de um elemento. Se nenhum argumento for especificado, a matriz retornada estará vazia. É definido abaixo.

d3.zip([10, 20], [30, 40]); // output is [[10, 30], [20, 40]]

Example - Crie uma página da web array_transform e adicione as seguintes alterações a ele.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 array API</h3>
      <script>
         console.log(d3.cross([10, 20], ["a", "b"]));
         console.log(d3.merge([[10], [30]]));
         console.log(d3.pairs([10, 20, 30, 40]));
         var object = {fruit:"mango", color: "yellow"},
         fields = ["fruit", "color"];
         console.log(d3.permute(object, fields)); 
         console.log(d3.zip([10, 20], [30, 40]));
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta.

Uma coleção é simplesmente um objeto que agrupa vários elementos em uma única unidade. Também é chamado de contêiner. Este capítulo explica em detalhes a API de coleções.

Configurando API

Você pode configurar a API usando o seguinte script.

<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script>

</script>

Métodos da API de coleções

A API de coleções contém objetos, mapas, conjuntos e ninhos. A seguir estão os métodos de API de coleções mais comumente usados.

  • API de objetos
  • API do Maps
  • API de conjuntos
  • API Nests

Vamos examinar cada uma dessas API em detalhes.

API de objetos

Object API é um dos tipos de dados importantes. Ele suporta os seguintes métodos -

  • d3.keys(object) - Este método contém as chaves de propriedade do objeto e retorna uma matriz dos nomes das propriedades.

  • d3.values(object) - Este método contém os valores do objeto e retorna uma matriz de valores de propriedade.

  • d3.entries(object)- Este método é usado para retornar uma matriz contendo chaves e valores do objeto especificado. Cada entrada é um objeto com uma chave e um valor.

Example - Vamos considerar o código a seguir.

d3.entries({one: 1})

Aqui, a chave é um e o valor é 1.

Example - Crie uma página da web objects.html e adicione as seguintes alterações a ele.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var month = {"jan": 1, "Feb": 2, "mar": 3, "apr": 4};
         console.log(d3.keys(month));
         console.log(d3.values(month));
         console.log(d3.entries(month));
      </script>
   </body>
</html>

Agora, solicite o navegador e você verá a seguinte resposta.

API do Maps

Um mapa contém valores com base em pares de chave e valor. Cada par de chave e valor é conhecido como uma entrada. Um mapa contém apenas chaves exclusivas. É útil pesquisar, atualizar ou excluir elementos com base na chave. Vamos examinar os vários métodos da API do Google Maps em detalhes.

  • d3.map([object[, key]])- Este método é usado para criar um novo mapa. O objeto é usado para copiar todas as propriedades enumeráveis.

  • map.has(key) - Este método é usado para verificar se o mapa possui uma entrada para a string de chave especificada.

  • map.get(key) - Este método é usado para retornar o valor da string de chave especificada.

  • map.set(key, value)- Este método é usado para definir o valor da string de chave especificada. Se o mapa anteriormente tinha uma entrada para a mesma string de chave, a entrada antiga é substituída pelo novo valor.

  • map.remove(key)- É usado para remover a entrada do mapa. Se a chave não for especificada, ele retornará falso.

  • map.clear() - Remove todas as entradas deste mapa.

  • map.keys() - Retorna uma matriz de chaves de string para cada entrada neste mapa.

  • map.values() - Retorna uma matriz de valores para cada entrada neste mapa.

  • map.entries() - Retorna uma matriz de objetos de valor-chave para cada entrada neste mapa.

  • (x) map.each(function) - Este método é usado para chamar a função especificada para cada entrada no mapa.

  • (xi) map.empty() - Retorna verdadeiro se e somente se este mapa tiver zero entradas.

  • (xii) map.size() - Retorna o número de entradas neste mapa.

Example - Crie uma página da web maps.html e adicione as seguintes alterações a ele.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var month = d3.map([{name: "jan"}, {name: "feb"}], 
            function(d) { return d.name; });
         console.log(month.get("jan")); // {"name": "jan"}
         console.log(month.get("apr")); // undefined
         console.log(month.has("feb")); // true
         
         var map =  d3.map().set("fruit", "mango");
         console.log(map.get("fruit")); // mango
         console.log(map.remove("fruit")); // remove key and return true.
         console.log(map.size());    // size is 0 because key removed.
         console.log(map.empty());   // true
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta.

Da mesma forma, você também pode realizar outras operações.

API de conjuntos

Um conjunto é uma coleção que não pode conter elementos duplicados. Ele modela a abstração matemática do conjunto. Vamos examinar os vários métodos da API Sets em detalhes.

  • d3.set([array[, accessor]])- Este método é usado para criar um novo conjunto. Array é usado para adicionar valores de string. Um acessador é opcional.

  • set.has(value) - Este método é usado para verificar se o conjunto possui uma entrada para a string de valor especificada.

  • set.add(value) - É usado para adicionar a string de valor especificada ao conjunto.

  • set.remove(value) - É usado para remover o conjunto que contém a string de valor especificada.

  • set.clear() - Remove todos os valores deste conjunto.

  • set.values() - Este método é usado para retornar uma matriz de valores para o conjunto.

  • set.empty() - Retorna verdadeiro se e somente se este conjunto tiver valores zero.

  • set.size() - Retorna o número de valores neste conjunto.

Example - Crie uma página da web sets.html e adicione as seguintes alterações a ele.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var fruits =  d3.set().add("mango")
          .add("apple").add("orange");
         console.log(fruits.has("grapes")); // return false.
         console.log(fruits.remove("apple")); //true
         console.log(fruits.size());    // size is 2
         console.log(fruits.empty());   // true
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta em nossa tela.

Da mesma forma, podemos realizar outras operações também.

API Nests

A API de aninhamento contém elementos em matriz e atua em uma estrutura de árvore hierárquica. Vamos examinar os vários métodos da API Nests em detalhes.

  • d3.nest() - Este método é usado para criar um novo ninho.

  • nest.key(key)- Este método é usado para inicializar uma nova função de tecla. Esta função é usada para chamar cada elemento em uma matriz de entrada e retornar elementos no grupo.

  • nest.sortKeys(comparator)- Este método é usado para classificar chaves em um comparador especificado. A função é definida como d3.ascending ou d3.descending.

  • nest.sortValues(comparator)- Este método é usado para classificar valores em um comparador especificado. A função de comparador classifica os elementos folha.

  • nest.map(array)- Este método é usado para aplicar a matriz especificada e retornar um mapa aninhado. Cada entrada no mapa retornado corresponde a um valor de chave distinto retornado pela primeira função de chave. O valor da entrada depende do número de funções chave registradas.

  • nest.object(array) - Este método é usado para aplicar o operador de aninhamento à matriz especificada e retornar um objeto aninhado.

  • nest.entries(array) - Este método é usado para aplicar o operador de aninhamento à matriz especificada e retornar uma matriz de entradas de valores-chave.

Considere uma página da web simples nest.html para executar os métodos de nidificação discutidos acima.

Example - Vamos considerar o seguinte exemplo.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 Nest API</h3>
      <script>
         var data = [
            {
               "color" : "red",
               "key" : 1
            },
            {
               "color" : "green",
               "key" : 2
            },
            {
               "color" : "blue",
               "key" : 75
            }
         ]
         var nest =  d3.nest()
            .key(function (d) { return d.color; })
            .entries(data)console.log(nest);
         var filter = nest.filter(function (d) { return d.key = = = 'red' })
         console.log(filter);
      </script>
   </body>
</html>

Agora, verifique o resultado em um navegador e veremos o seguinte resultado.

Array[3]
0: Object
1: Object
2: Object
length: 3
__proto__: Array[0]

Array[1]
0: Object
length: 1
__proto__: Array[0]

As seleções são uma poderosa transformação orientada a dados do modelo de objeto de documento (DOM). É usado para definir atributos, estilos, propriedades, HTML ou conteúdo de texto e muito mais. Este capítulo explica a API de seleções em detalhes.

Configurando a API

Você pode configurar a API diretamente usando o script abaixo.

<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script>

</script>

Métodos de API de seleção

A seguir estão os métodos mais importantes na API de seleção.

  • d3.selection()
  • d3.select(selector)
  • d3.selectAll(selector)
  • selection.selectAll(selector)
  • selection.filter(filter)
  • selection.merge(other)
  • d3.matcher(selector)
  • d3.creator(name)
  • selection.each(function)
  • selection.call (função [, argumentos ...])
  • d3.local()
  • local.set (nó, valor)
  • local.get(node)
  • local.remove(node)

Vamos agora discutir cada um deles em detalhes.

d3.selection ()

Este método é usado para selecionar o elemento raiz. Esta função também pode ser usada para testar seleções ou estender a seleção d3js.

d3.select (seletor)

Este método é usado para selecionar o primeiro elemento que corresponda à string do seletor especificada.

Example - Vamos considerar o seguinte exemplo.

var body = d3.select("body");

Se o seletor não for uma string, ele seleciona o nó especificado, que é definido a seguir.

d3.select("p").style("color", "red");

d3.selectAll (seletor)

Este método seleciona todos os elementos que correspondem à string do seletor especificada.

Example - Vamos considerar o seguinte exemplo.

var body = d3.selectAll("body");

Se o seletor não for uma string, ele seleciona a matriz especificada de nós, que é definida abaixo.

d3.selectAll("body").style("color", "red");

selection.selectAll (seletor)

Este método é usado para selecionar um elemento. Ele seleciona os elementos descendentes que correspondem à string do seletor especificada. Os elementos na seleção retornada são agrupados por seu nó pai correspondente nesta seleção. Se nenhum elemento corresponder ao seletor especificado para o elemento atual, ou se o seletor for nulo, o grupo no índice atual estará vazio.

Example - Vamos considerar o seguinte exemplo.

var b = d3.selectAll("p").selectAll("b");

selection.filter (filtro)

Este método é usado para filtrar a seleção, retornando uma nova seleção que contém apenas os elementos para os quais o filtro especificado é verdadeiro.

Example - Vamos considerar o seguinte exemplo.

var even = d3.selectAll("tr").filter(":nth-child(odd)");

Aqui, filtrar uma seleção de linhas da tabela retorna apenas ímpar.

selection.merge (outro)

Este método é usado para retornar uma nova seleção mesclada com a outra seleção especificada.

Example - Vamos considerar o seguinte exemplo.

var rect = svg.selectAll("rect").data(data);
rect.enter().append("rect").merge(rect);

d3.matcher (seletor)

Este método é usado para atribuir o seletor especificado. Ele retorna uma função, que retorna verdadeiro.

Example - Vamos considerar o seguinte exemplo.

var p = selection.filter(d3.matcher("p"));

d3.creator (nome)

Este método é usado para atribuir o nome do elemento especificado. Ele retorna uma função, que cria um elemento com o nome fornecido, assumindo que este seja o elemento pai.

Example - Vamos considerar o seguinte exemplo.

selection.append(d3.creator("p"));

selection.each (função)

Este método é usado para invocar a função especificada para cada elemento selecionado, na ordem passada pelo datum atual (d), o índice atual (i) e o grupo atual (nós) com este como o elemento DOM atual (nós [i ]). Isso é explicado a seguir.

parent.each(function(p, j) {
   d3.select(this)
      .selectAll(".child")
      .text(function(d, i) { return "child " + d.name + " of " + p.name; });
});

selection.call (função [, argumentos ...])

É usado para chamar a função especificada exatamente uma vez. A sintaxe é mostrada abaixo.

function name(selection, first, last) {
   selection.attr("first-name", first).attr("last-name", last);
}

Este método pode ser especificado conforme mostrado abaixo.

d3.selectAll("p").call(name, "Adam", "David");

d3.local ()

D3 local permite definir o estado local que é independente dos dados.

Example - Vamos considerar o seguinte exemplo.

var data = d3.local();

Ao contrário de var, o valor de cada local também é definido pelo DOM.

local.set (nó, valor)

Este método define o valor deste local no nó especificado para o valor.

Example - Vamos considerar o seguinte exemplo.

selection.each(function(d) 
   { data.set(this, d.value); });
local.get(node)

Este método retorna o valor deste local no nó especificado. Se o nó não definir esse local, ele retornará o valor do ancestral mais próximo que o define.

local.remove (nó)

Este método exclui o valor deste local do nó especificado. Ele retorna verdadeiro, se o nó estiver definido, caso contrário, retorna falso.

Os caminhos são usados ​​para desenhar retângulos, círculos, elipses, polilinhas, polígonos, linhas retas e curvas. Os caminhos SVG representam o contorno de uma forma que pode ser traçada, preenchida, usada como caminho de recorte ou qualquer combinação dos três. Este capítulo explica a API Paths em detalhes.

Configurando caminhos

Você pode configurar a API Paths usando o script abaixo.

<script src = "https://d3js.org/d3-path.v1.min.js"></script>
<script>

</script>

Métodos de API de caminhos

Alguns dos métodos da API Paths mais comumente usados ​​são brevemente descritos a seguir.

  • d3.path() - Este método é usado para criar um novo caminho.

  • path.moveTo(x, y) - Este método é usado para mover os valores xey especificados.

  • path.closePath() - Este método é usado para fechar o caminho atual.

  • path.lineTo(x, y) - Este método é usado para criar uma linha do ponto atual até os valores x, y definidos.

  • path.quadraticCurveTo(cpx, cpy, x, y) - Este método é usado para desenhar uma curva quadrática do ponto atual ao ponto especificado.

  • path.bezierCurveTo(cpx1, cpy1, cpx2, cpy2, x, y) - Este método é usado para desenhar uma curva de Bezier do ponto atual ao ponto especificado.

  • path.arcTo(x1, y1, x2, y2, radius) - Este método é usado para desenhar um arco circular do ponto atual até um ponto especificado (x1, y1) e terminar a linha entre os pontos especificados (x1, y1) e (x2, y2).

  • path.arc(x, y, radius, startAngle, endAngle[, anticlockwise])- Este método é usado para desenhar um arco circular para o centro especificado (x, y), raio, startAngle e endAngle. Se o valor no sentido anti-horário for verdadeiro, então o arco é desenhado no sentido anti-horário, caso contrário, ele é desenhado no sentido horário.

  • path.rect(x, y, w, h)- Este método é usado para criar um novo subcaminho contendo apenas os quatro pontos (x, y), (x + w, y), (x + w, y + h), (x, y + h). Com esses quatro pontos conectados por linhas retas, marca o subcaminho como fechado. Equivalente a context.rect e usa os comandos “lineto” do SVG.

  • path.toString() - Retorna a representação de string deste caminho de acordo com a especificação de dados de caminho do SVG.

Exemplo

Vamos desenhar uma linha simples em D3 usando a API de caminho. Crie uma página da weblinepath.html e adicione as seguintes alterações nele.

<!DOCTYPE html>
<meta charset = "UTF-8">
   <head>
      <title>SVG path line Generator</title>
   </head>

   <style>
      path {
         fill: green;
         stroke: #aaa;
      }
   </style>
   
   <body>
      <svg width = "600" height = "100">
         <path transform = "translate(200, 0)" />
      </svg>
      
      <script src = "https://d3js.org/d3.v4.min.js"></script>
      <script>
         var data = [[0, 20], [50, 30], [100, 50], [200, 60], [300, 90]];
         var lineGenerator = d3.line();
         var pathString = lineGenerator(data);
         d3.select('path').attr('d', pathString);
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos o seguinte resultado.

D3.js fornece funções de escala para realizar transformações de dados. Essas funções mapeiam um domínio de entrada para um intervalo de saída.

Configurando API

Podemos configurar a API diretamente usando o seguinte script.

<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-format.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-time.v1.min.js"></script>
<script src = "https://d3js.org/d3-time-format.v2.min.js"></script>
<script src = "https://d3js.org/d3-scale.v1.min.js"></script>
<script>

</script>

Métodos de API de escalas

D3 fornece os seguintes métodos de escala importantes para diferentes tipos de gráficos. Vamos entender então em detalhes.

  • d3.scaleLinear() - Constrói uma escala linear contínua onde podemos inserir mapas de dados (domínio) para o intervalo de saída especificado.

  • d3.scaleIdentity() - Construa uma escala linear onde os dados de entrada são iguais aos de saída.

  • d3.scaleTime() - Construa uma escala linear onde os dados de entrada estão nas datas e a saída em números.

  • d3.scaleLog() - Construa uma escala logarítmica.

  • d3.scaleSqrt() - Construa uma escala de raiz quadrada.

  • d3.scalePow() - Construa uma escala exponencial.

  • d3.scaleSequential() - Construir uma escala sequencial onde a faixa de saída é fixada pela função de interpolador.

  • d3.scaleQuantize() - Construir uma escala de quantização com faixa de saída discreta.

  • d3.scaleQuantile() - Construa uma escala de quantil onde os dados de amostra de entrada sejam mapeados para a faixa de saída discreta.

  • d3.scaleThreshold() - Construa uma escala onde os dados de entrada arbitrários sejam mapeados para a faixa de saída discreta.

  • d3.scaleBand() - As escalas de banda são como escalas ordinais, exceto que a faixa de saída é contínua e numérica.

  • d3.scalePoint() - Construa uma escala de pontos.

  • d3.scaleOrdinal() - Construa uma escala ordinal em que os dados de entrada incluam alfabetos e sejam mapeados para a faixa de saída numérica discreta.

Antes de fazer um exemplo prático, vamos primeiro entender os dois termos a seguir -

  • Domain - O Domínio denota os valores mínimo e máximo de seus dados de entrada.

  • Range - O intervalo é o intervalo de saída, para o qual gostaríamos que os valores de entrada mapeassem ...

Exemplo de Trabalho

Vamos executar a função d3.scaleLinear neste exemplo. Para fazer isso, você precisa seguir as seguintes etapas -

Step 1 - Define variables - Defina variáveis ​​e dados SVG usando a codificação abaixo.

var data = [100, 200, 300, 400, 800, 0]
   var width = 500, 
      barHeight = 20, 
      margin = 1;

Step 2 - Create linear scale - Use o seguinte código para criar uma escala linear.

var scale = d3.scaleLinear()
   .domain([d3.min(data), d3.max(data)])
   .range([100, 400]);

Aqui, para o valor mínimo e máximo de nosso domínio manualmente, podemos usar o integrado d3.min() e d3.max() funções, que retornarão os valores mínimo e máximo, respectivamente, de nossa matriz de dados.

Step 3 - Append SVG attributes - Anexe os elementos SVG usando o código fornecido a seguir.

var svg = d3.select("body")
   .append("svg")
   .attr("width", width)
   .attr("height", barHeight * data.length);

Step 4 - Apply transformation - Aplique a transformação usando o código abaixo.

var g = svg.selectAll("g")
   .data(data).enter().append("g")
   .attr("transform", function (d, i) {
      return "translate(0," + i * barHeight + ")";
});

Step 5 - Append rect elements - Anexe os elementos retos à escala, conforme mostrado abaixo.

g.append("rect")
   .attr("width", function (d) {
      return scale(d);
   })
   .attr("height", barHeight - margin)

Step 6 - Display data - Agora exiba os dados usando a codificação fornecida abaixo.

g.append("text")
   .attr("x", function (d) { return (scale(d)); })
   .attr("y", barHeight / 2)
   .attr("dy", ".35em")
   .text(function (d) { return d; });

Step 7 - Working Example - Agora, vamos criar um gráfico de barras usando a função d3.scaleLinear () da seguinte maneira.

Crie uma página da web “escalas.html” e adicione as seguintes alterações a ela.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <script>
         var data = [100, 200, 300, 350, 400, 250]
         var width = 500, barHeight = 20, margin = 1;
         
         var scale = d3.scaleLinear()
            .domain([d3.min(data), d3.max(data)])
            .range([100, 400]);
         
         var svg = d3.select("body")
            .append("svg")
            .attr("width", width)
            .attr("height", barHeight * data.length);
         
         var g = svg.selectAll("g")
            .data(data)
            .enter()
            .append("g")
            .attr("transform", function (d, i) {
               return "translate(0," + i * barHeight + ")";
         });
    
         g.append("rect")
         .attr("width", function (d) {
            return scale(d);
         })
         
         .attr("height", barHeight - margin)
         g.append("text")
         .attr("x", function (d) { return (scale(d)); })
         .attr("y", barHeight / 2).attr("dy", ".35em")
         .text(function (d) { return d; });
      </script>
   </body>
</html>

O código acima exibirá o seguinte resultado no navegador.

D3 fornece funções para desenhar eixos. Um eixo é feito de linhas, carrapatos e rótulos. Um eixo usa uma escala, então cada eixo precisará receber uma escala para trabalhar.

Configurando a API Axis

Você pode configurar a API usando o seguinte script.

<script src = "https://d3js.org/d3-axis.v1.min.js"></script>
<script>

</script>

Métodos da API Axis

D3 fornece as seguintes funções significativas para desenhar eixos. Eles são descritos resumidamente a seguir.

  • d3.axisTop() - Este método é usado para criar um eixo horizontal superior.

  • d3.axisRight() - Este método é usado para criar um eixo vertical orientado para a direita.

  • d3.axisBottom() - Este método é usado para criar um eixo horizontal inferior.

  • d3.axisLeft() - Cria eixo vertical esquerdo.

Exemplo de Trabalho

Vamos aprender como adicionar os eixos xey a um gráfico. Para fazer isso, precisamos seguir as etapas abaixo.

Step 1 - Define variables - Defina SVG e variáveis ​​de dados usando o código abaixo.

var width = 400, height = 400;
var data = [100, 150, 200, 250, 280, 300];
var svg = d3.select("body")
   .append("svg")
   .attr("width", width)
   .attr("height", height);

Step 2 - Create a scale linear function - Crie uma função linear de escala para os eixos xey conforme definido abaixo.

var xscale = d3.scaleLinear()
   .domain([0, d3.max(data)])
   .range([0, width - 100]);

var yscale = d3.scaleLinear()
   .domain([0, d3.max(data)])
   .range([height/2, 0]);

Aqui, criamos uma escala linear e especificamos o domínio e o intervalo.

Step 3 - Add scales to x-axis - Agora, podemos adicionar escalas ao eixo x usando o código a seguir.

var x_axis = d3.axisBottom()
   .scale(xscale);

Aqui, usamos d3.axisBottom para criar nosso eixo xe fornecê-lo com a escala, que é definida anteriormente.

Step 4 - Add scales to the y-axis - Use o seguinte código para adicionar escalas ao eixo y.

var y_axis = d3.axisLeft()
   .scale(yscale);

Aqui, usamos o d3.axisLeft para criar nosso eixo y e fornecê-lo com a escala que definimos acima.

Step 5 - Apply transformation - Você pode anexar um elemento de grupo e inserir os eixos x, y, que é definido abaixo.

svg.append("g")
   .attr("transform", "translate(50, 10)")
   .call(y_axis);

Step 6 - Append group elements - Aplique elementos de transição e grupo usando o código a seguir.

var xAxisTranslate = height/2 + 10;
svg.append("g")
   .attr("transform", "translate(50, " + xAxisTranslate  +")")
   .call(x_axis)

Step 7 - Working Example- A listagem completa do código é fornecida no seguinte bloco de código. Crie uma página da webaxes.html e adicione as seguintes alterações a ele.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         svg text {
            fill: purple;
            font: 12px sans-serif;
            text-anchor: end;
         }
      </style>
   </head>

   <body>
      <script>
         var width = 400, height = 400;
         var data = [100, 120, 140, 160, 180, 200];
         var svg = d3.select("body")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         
         var xscale = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([0, width - 100]);
         
         var yscale = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([height/2, 0]);
    
         var x_axis = d3.axisBottom().scale(xscale);
         
         var y_axis = d3.axisLeft().scale(yscale);
         
         svg.append("g")
            .attr("transform", "translate(50, 10)")
            .call(y_axis);
         
         var xAxisTranslate = height/2 + 10;
         
         svg.append("g")
            .attr("transform", "translate(50, " + xAxisTranslate  +")")
            .call(x_axis)
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos as seguintes alterações.

Este capítulo discute os diferentes geradores de forma em D3.js.

Configurando API

Você pode configurar a API Shapes usando o seguinte script.

<script src = "https://d3js.org/d3-path.v1.min.js"></script>
<script src = "https://d3js.org/d3-shape.v1.min.js"></script>
<script>

</script>

Geradores de formas

D3.js oferece suporte a diferentes formas. Vamos examinar detalhadamente as formas proeminentes.

API Arcs

O gerador de arco produz uma forma de círculo ou anel. Usamos esses métodos de API no capítulo anterior de gráficos de pizza. Vamos entender os vários métodos da API Arcs em detalhes.

  • d3.arc() - Este método é usado para criar um novo gerador de arco.

  • arc(args)- É usado para gerar um arco com os argumentos fornecidos especificados. As configurações padrão com raios e ângulos de um objeto são definidas abaixo.

<script>
   var arc = d3.arc();
   arc({
      innerRadius: 0,
      outerRadius: 100,
      startAngle: 0,
      endAngle: Math.PI / 2
   });
</script>
  • arc.centroid(args) - Este método é usado para calcular o ponto médio [x, y] da linha central do arco com os argumentos especificados.

  • arc.innerRadius([radius])- Este método é usado para definir o raio interno do raio dado e retornar um gerador de arco. É definido abaixo -

function innerRadius(d) {
   return d.innerRadius;
}
  • arc.outerRadius([radius])- Este método é usado para definir o raio externo do raio dado e retornar um gerador de arco. É definido como segue.

function outerRadius(d) {
   return d.outerRadius;
}
  • arc.cornerRadius([radius])- Este método é usado para definir o raio do canto a partir do raio fornecido e retornar um gerador de arco. É definido como segue.

function cornerRadius() {
   return 0;
}

Se o raio do canto for maior que zero, os cantos do arco serão arredondados usando os círculos do raio fornecido. O raio do canto não pode ser maior que (outerRadius - innerRadius) / 2.

  • arc.startAngle([angle])- Este método é usado para definir o ângulo inicial da função a partir do ângulo fornecido. É definido da seguinte forma -

function startAngle(d) {
   return d.startAngle;
}
  • arc.endAngle([angle])- Este método é usado para definir o ângulo final para a função a partir do ângulo fornecido. É definido como segue.

function endAngle(d) {
   return d.endAngle;
}
  • arc.padAngle([angle])- Este método é usado para definir o ângulo da almofada para a função a partir do ângulo fornecido. É definido como segue.

function padAngle() {
   return d && d.padAngle;
}
  • (x) arc.padRadius([radius])- Este método é usado para definir o raio da almofada para a função especificada a partir do raio fornecido. O raio da almofada determina a distância linear fixa que separa os arcos adjacentes, definida como padRadius * padAngle.

  • (xi) arc.context([context]) - Este método é usado para definir o contexto e retornar um gerador de arco.

API de tortas

Esta API é usada para criar um gerador de pizza. Executamos esses métodos de API no capítulo anterior. Discutiremos todos esses métodos em detalhes.

  • d3.pie() - Constrói um novo gerador de pizza com as configurações padrão.

  • pie(data[, arguments])- Este método é usado para gerar uma pizza para os valores de matriz fornecidos. Ele retorna uma série de objetos. Objetos são ângulos de arco de referência. Cada objeto possui as seguintes propriedades -

    • data- o dado de entrada; o elemento correspondente na matriz de dados de entrada.

    • value - o valor numérico do arco.

    • index - índice do arco.

    • startAngle - o ângulo inicial do arco.

    • endAngle - o ângulo final do arco.

    • padAngle - o ângulo da almofada do arco.

  • pie.value([value])- Este método é usado para definir o valor da função especificada e gerar uma pizza. É definido da seguinte forma -

function value(d) {
   return d;
}
  • pie.sort([compare])- Este método é usado para classificar os dados para a função especificada e gerar pizza. A função de comparação é definida como segue.

pie.sort(function(a, b) 
   { return a.name.localeCompare(b.name); }
);

Aqui, a função de comparação leva dois argumentos 'a' e 'b', cada elemento da matriz de dados de entrada. Se o arco para 'a' deve estar antes do arco para 'b', então o comparador deve retornar um número menor que zero. Se o arco para 'a' deve estar após o arco para 'b', então o comparador deve retornar um número maior que zero.

  • pie.sortValues([compare])- Este método é usado para comparar o valor da função dada e gera uma pizza. A função é definida da seguinte maneira.

function compare(a, b) {
   return b - a;
}
  • pie.startAngle([angle])- Este método é usado para definir o ângulo inicial da pizza para a função especificada. Se o ângulo não for especificado, ele retorna o ângulo inicial atual. É definido como segue.

function startAngle() {
   return 0;
}
  • pie.endAngle([angle])- Este método é usado para definir o ângulo final da pizza para a função especificada. Se o ângulo não for especificado, ele retorna o ângulo final atual. É definido como segue.

function endAngle() {
   return 2 * Math.PI;
}
  • pie.padAngle([angle])- Este método é usado para definir o ângulo da almofada para a função especificada e gera a pizza. A função é definida da seguinte maneira.

function padAngle() {
   return 0;
}

API de linhas

A API de linhas é usada para gerar uma linha. Usamos esses métodos de API noGraphscapítulo. Vamos examinar cada método em detalhes.

  • d3.line() - Este método é usado para criar um novo gerador de linha.

  • line(data) - Este método é usado para gerar uma linha para a matriz de dados fornecida.

  • line.x([x])- Este método é usado para definir o acessador x para a função especificada e gerar uma linha. A função é definida abaixo,

function x(d) {
   return d[0];
}
  • line.y([y])- Este método é usado para definir o acessador 'y' 'para a função especificada e gera uma linha. A função é definida da seguinte maneira.

function y(d) {
   return d[1];
}
  • line.defined([defined])- Este método é usado para definir o acessador definido para a função especificada. É definido como segue.

function defined() {
  return true;
}
  • line.curve([curve]) - É usado para definir a curva e gerar a linha.

  • line.context([context])- Este método é usado para definir o contexto e gerar uma linha. Se o contexto não for especificado, ele retornará nulo.

  • d3.lineRadial()- Este método é usado para criar uma nova linha radial; é equivalente ao gerador de linha cartesiano.

  • lineRadial.radius([radius])- Este método é usado para desenhar uma linha radial e o acessador retorna o raio. Leva distância da origem (0,0).

No próximo capítulo, aprenderemos sobre a API Colors em D3.js.

As cores são exibidas combinando VERMELHO, VERDE e AZUL. As cores podem ser especificadas das seguintes maneiras diferentes -

  • Por nomes de cores
  • Como valores RGB
  • Como valores hexadecimais
  • Como valores HSL
  • Como valores HWB

A API d3-color fornece representações para várias cores. Você pode realizar operações de conversão e manipulação na API. Vamos entender essas operações em detalhes.

Configurando API

Você pode carregar a API diretamente usando o seguinte script.

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script>

</script>

Operações básicas

Vamos examinar as operações básicas de cores em D3.

Convert color value to HSL - Para converter o valor da cor em HSL, use o seguinte Example -

var convert = d3.hsl("green");

Você pode girar o matiz em 45 °, conforme mostrado abaixo.

convert.h + =  45;

Da mesma forma, você também pode alterar o nível de saturação. Para esmaecer o valor da cor, você pode alterar o valor da opacidade conforme mostrado abaixo.

convert.opacity = 0.5;

Métodos Color API

A seguir estão alguns dos métodos de API de cores mais importantes.

  • d3.color(specifier)
  • color.opacity
  • color.rgb()
  • color.toString()
  • color.displayable()
  • d3.rgb(color)
  • d3.hsl(color)
  • d3.lab(color)
  • d3.hcl(color)
  • d3.cubehelix(color)

Vamos entender cada um desses métodos de API de cores em detalhes.

d3.color (especificador)

É usado para analisar a cor CSS especificada e retornar a cor RGB ou HSL. Se o especificador não for fornecido, será retornado nulo.

Example - Vamos considerar o seguinte exemplo.

<script>
   var color = d3.color("green");  // asign color name directly
   console.log(color);
</script>

Veremos a seguinte resposta em nossa tela -

{r: 0, g: 128, b: 0, opacity: 1}

color.opacity

Se quisermos esmaecer a cor, podemos alterar o valor da opacidade. Está na faixa de [0, 1].

Example - Vamos considerar o seguinte exemplo.

<script>
   var color = d3.color("green");
   console.log(color.opacity);
</script>

Veremos a seguinte resposta na tela -

1

color.rgb ()

Ele retorna o valor RGB da cor. Vamos considerar o seguinte exemplo.

<script>
   var color = d3.color("green");
   console.log(color.rgb());
</script>

Veremos a seguinte resposta em nossa tela.

{r: 0, g: 128, b: 0, opacity: 1}

color.toString ()

Ele retorna uma string que representa a cor de acordo com a especificação CSS Object Model. Vamos considerar o seguinte exemplo.

<script>
   var color = d3.color("green");
   console.log(color.toString());
</script>

Veremos a seguinte resposta em nossa tela.

rgb(0, 128, 0)

color.displayable ()

Retorna verdadeiro, se a cor puder ser exibida. Retorna falso, se o valor da cor RGB for menor que 0 ou maior que 255, ou se a opacidade não estiver no intervalo [0, 1]. Vamos considerar o seguinte exemplo.

<script>
   var color = d3.color("green");
   console.log(color.displayable());
</script>

Veremos a seguinte resposta em nossa tela.

true

d3.rgb (cor)

Este método é usado para construir uma nova cor RGB. Vamos considerar o seguinte exemplo.

<script>
   console.log(d3.rgb("yellow"));
   console.log(d3.rgb(200,100,0));
</script>

Veremos a seguinte resposta na tela.

{r: 255, g: 255, b: 0, opacity: 1}
{r: 200, g: 100, b: 0, opacity: 1}

d3.hsl (cor)

É usado para construir uma nova cor HSL. Os valores são expostos como propriedades h, s e l na instância retornada. Vamos considerar o seguinte exemplo.

<script>
   var hsl = d3.hsl("blue");
   console.log(hsl.h + =  90);
   console.log(hsl.opacity = 0.5);
</script>

Veremos a seguinte resposta na tela.

330
0.5

d3.lab (cor)

Ele constrói uma nova cor de laboratório. Os valores do canal são expostos como propriedades 'l', 'a' e 'b' na instância retornada.

<script>
   var lab = d3.lab("blue");
   console.log(lab);
</script>

Veremos a seguinte resposta na tela.

{l: 32.29701093285073, a: 79.18751984512221, b: -107.8601617541481, opacity: 1}

d3.hcl (cor)

Constrói uma nova cor HCL. Os valores do canal são expostos como propriedades h, c e l na instância retornada. Vamos considerar o seguinte exemplo.

<script>
   var hcl = d3.hcl("blue");
   console.log(hcl);
</script>

Veremos a seguinte resposta na tela.

{h: 306.2849380699878, c: 133.80761485376166, l: 32.29701093285073, opacity: 1}

d3.cubehelix (cor)

Constrói uma nova cor Cubehelix. Os valores são expostos como propriedades h, s e l na instância retornada. Vamos considerar o seguinte exemplo.

<script>
   var hcl = d3.hcl("blue");
   console.log(hcl);
</script>

Veremos a seguinte resposta na tela,

{h: 236.94217167732103, s: 4.614386868039719, l: 0.10999954957200976, opacity: 1}

Exemplo de Trabalho

Vamos criar uma nova página da web - color.htmlpara executar todos os métodos API de cores. A lista completa de códigos é definida abaixo.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 colors API</h3>
      <script>
         var color = d3.color("green");
         console.log(color);
         console.log(color.opacity);
         console.log(color.rgb());
         console.log(color.toString());
         console.log(color.displayable());
         console.log(d3.rgb("yellow"));
         console.log(d3.rgb(200,100,0));
         var hsl = d3.hsl("blue");
         console.log(hsl.h + =  90);
         console.log(hsl.opacity = 0.5);
         var lab = d3.lab("blue");
         console.log(lab);
         var hcl = d3.hcl("blue");
         console.log(hcl);
         var cube = d3.cubehelix("blue");
         console.log(cube);
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta.

As transições D3 levam uma seleção de elementos e para cada elemento; ele aplica uma transição a uma parte da definição atual do elemento.

Configurando API

Você pode configurar a API de transição usando o seguinte script.

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-ease.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script src = "https://d3js.org/d3-transition.v1.min.js"></script>
<script>

</script>

Métodos de API de transição

Vamos examinar os métodos da API de transição em detalhes.

Selecionando Elementos

Vamos discutir os vários elementos de seleção em detalhes.

  • selection.transition([name])- Este método é usado para retornar uma nova transição de seleção com o nome. Se um nome não for especificado, ele retornará nulo.

  • selection.interrupt([name]) - Este método é usado para interromper os elementos selecionados da transição com o nome e é definido a seguir.

selection.interrupt().selectAll("*").interrupt();
  • d3.interrupt(node[, name]) - Este método é usado para interromper a transição do nome especificado no nó especificado.

  • d3.transition([name]) - Este método é usado para retornar uma nova transição com o nome especificado.

  • transition.select(selector) - Este método é usado para selecionar o primeiro elemento que corresponde ao seletor especificado e retorna uma transição na seleção resultante, que é definida abaixo.

transition
   .selection()
   .select(selector)
   .transition(transition)
  • transition.selectAll(selector)- Este método é usado para selecionar todos os elementos que correspondem ao seletor especificado e retorna uma transição na seleção resultante. É definido abaixo -

transition
   .selection()
   .selectAll(selector)
   .transition(transition)
  • transition.filter(filter) - Este método é usado para selecionar os elementos que correspondem ao filtro especificado, eles são definidos abaixo.

transition
   .selection()
   .filter(filter)
   .transition(transition)
  • transition.merge(other)- Este método é usado para mesclar a transição com outra transição. É definido abaixo.

transition
   .selection()
   .merge(other.selection())
   .transition(transition)
  • transition.transition()- Este método é usado para retornar uma nova transição nos elementos selecionados. Está programado para começar quando a transição terminar. A nova transição herda o nome, a duração e o easing desta transição.

Example - Vamos considerar o seguinte exemplo.

d3.selectAll(".body")
   .transition() 
   
   // fade to yellow.
   .style("fill", "yellow")
   .transition() 
   
   // Wait for five second. Then change blue, and remove.
   .delay(5000)
   .style("fill", "blue")
   .remove();

Aqui, o corpo desvanece para amarelo e começa apenas cinco segundos antes da última transição.

  • d3.active(node[, name]) - Este método é usado para retornar a transição no nó especificado com o nome.

Métodos de tempo

Vamos examinar os métodos da API de tempo de transição em detalhes.

  • transition.delay([value])- Este método é usado para definir o atraso de transição para o valor especificado. Se uma função for avaliada para cada elemento selecionado, ela será passada para o datum atual 'd' e índice 'i', com o contexto como o elemento DOM atual. Se um valor não for especificado, retorna o valor atual do atraso para o primeiro elemento (não nulo) na transição. É definido abaixo,

transition.delay(function(d, i) { return i * 10; });
  • transition.duration([value])- Este método é usado para definir a duração da transição para o valor especificado. Se um valor não for especificado, retorna o valor atual da duração para o primeiro elemento (não nulo) na transição.

  • transition.ease([value])- Este método é usado para facilitar o valor de transição para elementos selecionados. A função de atenuação é chamada para cada quadro da animação e passa o tempo normalizado 't' no intervalo [0, 1]. Se um valor não for especificado, ele retornará a função de atenuação atual para o primeiro elemento (não nulo) na transição.

No próximo capítulo, discutiremos o conceito de arrastar e soltar no d3.js.

Arrastar e soltar é um dos conceitos mais familiares no d3.js. Este capítulo explica como arrastar e seus métodos em detalhes.

Instalação

Podemos incluir arrastar API diretamente usando o seguinte script.

<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-drag.v1.min.js"></script>

Arrastando métodos de API

A seguir estão alguns dos métodos de API de arrastar mais importantes em D3.js.

  • d3.drag()
  • drag(selection)
  • drag.container([container])
  • drag.filter([filter])
  • drag.subject([subject])
  • drag.clickDistance([distance])
  • drag.on (nomes de tipo, [ouvinte])
  • d3.dragDisable(window)
  • d3.dragEnable (janela [, noclick])

Vamos agora entender cada um deles em detalhes.

d3.drag ()

Este método é usado para criar um novo arrasto. Você pode chamar esse método usando o seguinte script.

<script>
   var drag = d3.drag();
</script>

arrastar (seleção)

Este método é usado para aplicar o arrastar à seleção especificada. Você pode invocar esta função usandoselection.call. Um exemplo simples é definido abaixo.

d3.select(".node").call(d3.drag().on("drag", mousemove));

Aqui, o comportamento de arrastar aplicado aos elementos selecionados é por meio de selection.call.

drag.container([container])

É usado para definir o contêiner para a função especificada para arrastar. Se um contêiner não for especificado, ele retornará o acessador atual. Para arrastar qualquer elemento gráfico com um Canvas, você pode redefinir o contêiner como ele mesmo. É definido abaixo.

function container() {
   return this;
}

drag.filter ([filtro])

É usado para definir o filtro para a função especificada. Se o filtro não for especificado, ele retornará o filtro atual conforme definido abaixo.

function filter() {
   return !d3.event.button;
}

drag.subject ([assunto])

É usado para definir o assunto para a função especificada para arrastar e é definido abaixo.

function subject(d) {
   return d = =  null ? {x: d3.event.x, y: d3.event.y} : d;
}

Aqui, o assunto representa a coisa que está sendo arrastada. Por exemplo, se você deseja arrastar elementos do retângulo em SVG, o assunto padrão é o datum do retângulo que está sendo arrastado.

drag.clickDistance ([distance])

Este método é usado para definir a distância máxima para clicar em um evento de mouse para baixo e mouseup. Se a distância não for especificada, ele aponta para zero.

drag.on (nomes de tipo, [ouvinte])

Este método é usado para definir o ouvinte de evento para os nomes de tipo especificados para arrastar. Os nomes de tipo são uma string contendo um ou mais nomes de tipo separados por espaços em branco. Cada nome de tipo é um tipo, opcionalmente seguido por um ponto (.) E um nome, como drag.one e drag.two. Este tipo deve ser de um dos seguintes -

  • start - inicia um novo ponteiro.

  • drag - arrasta um ponteiro ativo.

  • end - Inativo um ponteiro ativo.

d3.dragDisable (janela)

Este método é usado para desativar a seleção de arrastar e soltar. Impede a ação do evento do mouseedown. A maioria dos navegadores selecionados suporta esta ação por padrão. Se não houver suporte, você pode definir a propriedade CSS como nenhum.

d3.dragEnable (janela [, noclick])

Este método é usado para habilitar a seleção de arrastar e soltar no local especificado da janela. É usado para chamar a ação do evento mouseup. Se você atribuir o valor noclick for true, o evento click expira um tempo limite de zero milissegundo.

API de arrastamento - eventos de arrastamento

O método D3.event é usado para definir o evento de arrastar. Consiste nos seguintes campos -

  • Target - Representa o comportamento de arrasto.

  • Type - É uma string e pode ser qualquer um dos seguintes - “iniciar”, “arrastar” ou “finalizar”.

  • Subject - O assunto de arrastar, definido por drag.subject.

event.on (nomes de tipo, [ouvinte])

O objeto de evento expõe o método event.on para executar o arrastamento. É definido como segue.

d3.event.on("drag", dragged).on("end", ended);

O zoom ajuda a dimensionar seu conteúdo. Você pode focar em uma determinada região usando a abordagem clicar e arrastar. Neste capítulo, discutiremos a API de zoom em detalhes.

Configurando API

Você pode carregar a API de zoom diretamente do “d3js.org” usando o seguinte script.

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-ease.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script src = "https://d3js.org/d3-transition.v1.min.js"></script>
<script src = "https://d3js.org/d3-drag.v1.min.js"></script>
<script src = "https://d3js.org/d3-zoom.v1.min.js"></script>

<body>
   <script>
   </script>
</body>

Métodos de API de zoom

A seguir estão alguns dos métodos de API de zoom mais comumente usados.

  • d3.zoom()
  • zoom(selection)
  • zoom.transform (seleção, transformação)
  • zoom.translateBy (seleção, x, y)
  • zoom.translateTo (seleção, x, y)
  • zoom.scaleTo (seleção, k)
  • zoom.scaleBy (seleção, k)
  • zoom.filter([filter])
  • zoom.wheelDelta([delta])
  • zoom.extent([extent])
  • zoom.scaleExtent([extent])
  • zoom.translateExtent([extent])
  • zoom.clickDistance([distance])
  • zoom.duration([duration])
  • zoom.interpolate([interpolate])
  • zoom.on (nomes de tipo [, ouvinte])

Vamos examinar resumidamente todos esses métodos de API de zoom.

d3.zoom ()

Ele cria um novo comportamento de zoom. Podemos acessá-lo usando o script abaixo.

<script>
   var zoom = d3.zoom();
</script>

zoom (seleção)

É usado para aplicar a transformação de zoom em um elemento selecionado. Por exemplo, você pode instanciar um comportamento mousedown.zoom usando a seguinte sintaxe.

selection.call(d3.zoom().on("mousedown.zoom", mousedowned));

zoom.transform (seleção, transformação)

É usado para definir a transformação de zoom atual dos elementos selecionados para a transformação especificada. Por exemplo, podemos redefinir a transformação de zoom para a transformação de identidade usando a sintaxe abaixo.

selection.call(zoom.transform, d3.zoomIdentity);

Também podemos redefinir a transformação de zoom para a transformação de identidade por 1000 milissegundos usando a seguinte sintaxe.

selection.transition().duration(1000).call(zoom.transform, d3.zoomIdentity);

zoom.translateBy (seleção, x, y)

É usado para traduzir a transformação de zoom atual dos elementos selecionados pelos valores xey. Você pode especificar os valores de conversão xey como números ou como funções que retornam números. Se uma função for chamada para o elemento selecionado, ela será passada através do datum atual 'd' e índice 'i' para DOM. Um código de amostra é definido abaixo.

zoom.translateBy(selection, x, y) {
   zoom.transform(selection, function() {
      return constrain(this.__zoom.translate(
         x = = = "function" ? x.apply(this, arguments) : x,
         y = = = "function" ? y.apply(this, arguments) : y
      );
   }
};

zoom.translateTo (seleção, x, y)

É usado para traduzir a transformação de zoom atual dos elementos selecionados para a posição especificada de xe y.

zoom.scaleTo (seleção, k)

É usado para dimensionar a transformação de zoom atual dos elementos selecionados para k. Aqui,k é um fator de escala, especificado como números ou funções.

zoom.scaleTo = function(selection, k) {
   zoom.transform(selection, function() {
      k = = = "function" ? k.apply(this, arguments) : k;
   });
};

zoom.scaleBy (seleção, k)

É usado para dimensionar a transformação zoon atual dos elementos selecionados por k. Aqui,k é um fator de escala, especificado como números ou como funções que retornam números.

zoom.scaleBy = function(selection, k) {
   zoom.scaleTo(selection, function() {
      var k0 = this.__zoom.k,
      k1 = k = = = "function" ? k.apply(this, arguments) : k;
      return k0 * k1;
   });
};

zoom.filter ([filtro])

É usado para definir o filtro para a função especificada para o comportamento do zoom. Se o filtro não for especificado, ele retornará o filtro atual conforme mostrado abaixo.

function filter() {
   return !d3.event.button;
}

zoom.wheelDelta ([delta])

O valor de Δé retornado pela função delta da roda. Se delta não for especificado, ele retorna a função delta da roda atual.

zoom.extent ([extensão])

É usado para definir a extensão dos pontos especificados da matriz. Se a extensão não for especificada, ele retornará o acessador de extensão atual, cujo padrão é [[0, 0], [largura, altura]], onde largura é a largura do cliente do elemento e altura é a altura do cliente.

zoom.scaleExtent ([extensão])

É usado para definir a extensão da escala para a matriz especificada de números [k0, k1]. Aqui,k0é o fator de escala mínimo permitido. Enquanto,k1é o fator de escala máximo permitido. Se a extensão não for especificada, ele retornará a extensão da escala atual, cujo padrão é [0, ∞]. Considere o código de amostra definido abaixo.

selection
   .call(zoom)
   .on("wheel", function() { d3.event.preventDefault(); });

O usuário pode tentar o zoom girando, quando já estiver no limite correspondente da extensão da escala. Se quisermos evitar a rolagem na entrada da roda, independentemente da extensão da escala, registre um ouvinte de evento da roda para evitar o comportamento padrão do navegador.

zoom.translateExtent ([extensão])

Se a extensão for especificada, ele define a extensão da translação para a matriz de pontos especificada. Se a extensão não for especificada, ele retornará a extensão de conversão atual, que é padronizada como [[-∞, -∞], [+ ∞, + ∞]].

zoom.clickDistance ([distance])

Este método é usado para definir a distância máxima que a área com zoom pode se mover entre para cima e para baixo, o que acionará um evento de clique subsequente.

zoom.duration ([duração])

Este método é usado para definir a duração das transições de zoom com um clique duplo e um toque duplo no número especificado de milissegundos e retorna o comportamento do zoom. Se a duração não for especificada, ele retornará a duração atual, que é padronizada para 250 milissegundos, definida abaixo.

selection
   .call(zoom)
   .on("dblclick.zoom", null);

zoom.interpolate ([interpolar])

Este método é usado para interpolar as transições de zoom para a função especificada. Se interpolate não for especificado, ele retorna a fábrica de interpolação atual, cujo padrão é d3.interpolateZoom.

zoom.on (nomes de tipo [, ouvinte])

Se o ouvinte for especificado, ele define o ouvinte de eventos para os nomes de tipo especificados e retorna o comportamento do zoom. Os nomes de tipo são uma string contendo um ou mais nomes de tipo separados por espaços em branco. Cada nome de tipo é um tipo, opcionalmente seguido por um ponto (.) E um nome, como zoom.um e zoom.segundo. O nome permite que vários ouvintes sejam registrados para o mesmo tipo. Este tipo deve ser de um dos seguintes -

  • Start - após o início do zoom (como no botão do mouse).

  • Zoom - após uma alteração na transformação do zoom (como no mousemove).

  • End - após o término do zoom (como no mouseup).

No próximo capítulo, discutiremos as diferentes solicitações de API em D3.js.

D3.js fornece uma API de solicitação para realizar o XMLHttpRequest. Este capítulo explica as várias APIs de solicitações em detalhes.

XMLHttpRequest

XMLHttpRequest é o cliente http integrado para emular o objeto XMLHttpRequest do navegador. Ele pode ser usado com JS projetado para navegadores para melhorar a reutilização de código e permitir o uso de bibliotecas existentes.

Você pode incluir o módulo em seu projeto e usá-lo como o objeto XHR baseado em navegador, conforme explicado abaixo.

var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
var xhr = new XMLHttpRequest();

Ele suporta solicitações assíncronas e síncronas e executa solicitações GET, POST, PUT e DELETE.

Configurando solicitações

Você pode carregar diretamente de “d3js.org” usando o script abaixo.

<script src = "https://d3js.org/d3-request.v1.min.js"></script>
<script>
   d3.json("/path/to/sample.json", callback);
</script>

Aqui, a API de solicitações tem suporte integrado para analisar JSON, CSV e TSV. Você pode analisar formatos adicionais usando a solicitação ou texto diretamente.

Carregar arquivos de texto

Para carregar um arquivo de texto, use a seguinte sintaxe.

d3.text("/path/to/sample.txt", function(error, text) {
   if (error) throw error;
   console.log(text); 
});

Analisando arquivos CSV

Para carregar e analisar um arquivo CSV, use a seguinte sintaxe.

d3.csv("/path/to/sample.csv", function(error, data) {
   if (error) throw error;
   console.log(data); 
});

Da mesma forma, você também pode carregar os arquivos JSON e TSV.

Exemplo de Trabalho

Vejamos um exemplo simples de como carregar e analisar um arquivo CSV. Antes disso, você precisa criar um arquivo CSV denominado “sample.csv” na pasta do seu aplicativo d3 conforme mostrado abaixo.

Num1,Num2
1,2
3,4
5,6
7,8
9,10

Agora, crie uma página da web “requests.html” usando o seguinte script.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3> D3.js Requests API </h3>
      <script>
         d3.csv("sample.csv", function(data) {
            console.log(data); 
         });
      </script>
   </body>
</html>

Agora, solicite o navegador e você verá a seguinte resposta,

Métodos de API de solicitações

A seguir estão alguns dos métodos de API de solicitações mais usados.

  • d3.request (url [, callback])
  • request.header (nome [, valor])
  • request.mimeType([type])
  • request.user([value])
  • request.password([value])
  • request.timeout([timeout])
  • request.get([data])
  • request.post([data])
  • request.send (método [, dados])
  • request.abort()
  • d3.csv (url [[linha], retorno de chamada])

Vamos agora discutir cada um deles brevemente.

d3.request (url [, callback])

Ele retorna uma nova solicitação para o URL fornecido. Se um retorno de chamada for atribuído, é considerado como um pedido de chamada, caso contrário, o pedido ainda não foi chamado. É definido abaixo.

d3.request(url)
   .get(callback);

Você pode postar alguns parâmetros de consulta usando a seguinte sintaxe.

d3.request("/path/to/resource")
   .header("X-Requested-With", "XMLHttpRequest")
   .header("Content-Type", "application/x-www-form-urlencoded")
   .post("a = 2&b = 3", callback);

Se você deseja especificar um cabeçalho de solicitação ou um tipo MIME, você não deve especificar um retorno de chamada para o construtor.

request.header (nome [, valor])

É usado para definir o valor do cabeçalho da solicitação com o nome especificado. Se nenhum valor for especificado, ele remove o cabeçalho da solicitação com o nome especificado. É definido abaixo.

d3.request(url)
   .header("Accept-Language", "en-US")
   .header("X-Requested-With", "XMLHttpRequest")
   .get(callback);

Aqui, o cabeçalho X-Requested-With para XMLHttpRequest é uma solicitação padrão.

request.mimeType ([type])

É usado para atribuir o tipo MIME ao valor fornecido. É definido abaixo.

d3.request(url)
   .mimeType("text/csv")
   .get(callback);

request.user ([value])

É usado para atribuir o nome de usuário para autenticação. Se um nome de usuário não for especificado, o padrão é null.

request.password ([value])

Se um valor for especificado, ele define a senha para autenticação.

request.timeout ([timeout])

Se um tempo limite for especificado, ele definirá o tempo limite para o número especificado de milissegundos.

request.get ([dados])

Este método é usado para enviar a solicitação com o método GET. É definido abaixo.

request.send("GET", data, callback);

request.post ([data])

Este método é usado para enviar a solicitação com o método POST. É definido abaixo.

request.send("POST", data, callback);

request.send (método [, dados])

Este método é usado para enviar a solicitação usando o método GET ou POST fornecido.

request.abort ()

Este método é usado para abortar a solicitação.

d3.csv (url [[linha], retorno de chamada])

Retorna uma nova solicitação para o arquivo CSV no URL especificado com o tipo Mime text / csv padrão. A sintaxe a seguir é exibida sem retorno de chamada.

d3.request(url)
   .mimeType("text/csv")
   .response(function(xhr) { return d3.csvParse(xhr.responseText, row); });

Se você especificar um retorno de chamada com o método POST, ele será definido a seguir.

d3.request(url)
   .mimeType("text/csv")
   .response(function(xhr) { return d3.csvParse(xhr.responseText, row); })
   .post(callback);

Exemplo

Crie um arquivo csv denominado “lang.csv” no diretório da pasta raiz do aplicativo d3 e adicione as seguintes alterações a ele.

Year,Language,Author
1972,C,Dennis Ritchie
1995,Java,James gosling
2011,D3 js,Mike Bostock

Crie uma página da web “csv.html” e adicione o seguinte script a ela.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3> D3.js request API</h3>
      <script>
         d3.csv("lang.csv", function(d) {
            return {
               year: new Date(+d.Year, 0, 1), // convert "Year" column to Date
               language: d.Language,
               author: d.Author,
            };
         }, function(error, rows) {
            console.log(error);
            console.log(rows[0].year);
         });
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta.

Um delimitador é uma sequência de um ou mais caracteres usados ​​para especificar o limite entre regiões separadas e independentes em texto simples ou outros dados. Um delimitador de campo é uma sequência de valores separados por vírgula. Bem, valores separados por delimitadores sãocomma separated values (CSV) ou tab-separated values(TSV). Este capítulo explica os valores separados por delimitador em detalhes.

Configurando API

Podemos facilmente carregar a API usando a seguinte sintaxe.

<script src = "https://d3js.org/d3-dsv.v1.min.js"></script>
<script>
   var data = d3.csvParse(string);
</script>

Métodos API

A seguir estão os vários métodos de API dos valores separados por delimitador.

  • d3.csvParse (string [, linha])
  • d3.csvParseRows (string [, linha])
  • d3.csvFormat (linhas [, colunas])
  • d3.csvFormatRows(rows)
  • d3.tsvParse (string [, linha])
  • d3.tsvParseRows (string [, linha])
  • d3.tsvFormat (linhas [, colunas])
  • d3.tsvFormatRows(rows)

Vamos examinar cada um desses métodos de API em detalhes.

d3.csvParse (string [, linha])

Este método é usado para analisar o formato csv. Considere o arquivodata.csv isso é mostrado abaixo.

year,population
2006,40
2008,45
2010,48
2012,51
2014,53
2016,57
2017,62

Agora, podemos aplicar a função fornecida acima.

Example - Vamos considerar o seguinte exemplo.

var data = d3.csvParse(string, function(d) {
   return {
      year: new Date(+d.Year, 0, 1), // lowercase and convert "Year" to Date
      population: d.population
   };
});

Aqui, ele analisa a string especificada nos valores separados por delimitador. Ele retorna uma matriz de objetos que representam as linhas analisadas.

d3.csvParseRows (string [, linha])

Este método é usado para analisar o formato csv equivalente a linhas.

var data = d3.csvParseRows(string, function(d, i) {
   return {
      year: new Date(+d[0], 0, 1), // convert first colum column to Date
      population: d[1],
   };
});

Ele analisa cada linha no arquivo csv.

d3.csvFormat (linhas [, colunas])

Este método é usado para formatar as linhas e colunas csv.

Example - Vamos considerar o seguinte exemplo.

var string = d3.csvFormat(data, ["year", "population"]);

Aqui, se as colunas não forem especificadas, a lista dos nomes das colunas que formam a linha do cabeçalho é determinada pela união de todas as propriedades em todos os objetos nas linhas. Se as colunas forem especificadas, é uma matriz de strings que representa os nomes das colunas.

d3.csvFormatRows (linhas)

Este método é usado para formatar as linhas csv.

Example - Vamos considerar o seguinte exemplo.

var string = d3.csvFormatRows(data.map(function(d, i) {
   return [
      d.year.getFullYear(), // Assuming d.year is a Date object.
      d.population
   ];
}));

Aqui, ele formata a matriz especificada de linhas de string como valores separados por delimitador, retornando uma string.

d3.tsvParse (string [, linha])

Este método é usado para analisar o formato tsv. É semelhante ao csvParse.

d3.tsvParseRows (string [, linha])

Este método é usado para analisar o formato tsv equivalente a linhas. É semelhante à função csvParseRows.

d3.tsvFormat (linhas [, colunas])

Este método é usado para formatar as linhas e colunas tsv.

d3.tsvFormatRows (linhas)

Este método é usado para formatar as linhas tsv.

O módulo Timer API é usado para executar as animações simultâneas com atraso de tempo sincronizado. UsarequestAnimationFramepara animação. Este capítulo explica o módulo Timer API em detalhes.

requestAnimationFrame

Este método informa ao navegador que você deseja executar uma animação e solicita que o navegador chame uma função especificada para atualizar uma animação.

Configurando o cronômetro

Podemos carregar facilmente o cronômetro diretamente do d3js.org usando o seguinte script.

<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script>
   var timer = d3.timer(callback);
</script>

Métodos da API Timer

A API Timer oferece suporte aos seguintes métodos importantes. Tudo isso é explicado em detalhes a seguir.

d3.now ()

Este método retorna a hora atual.

d3.timer (callback [, delay [, time]])

Este método é usado para agendar um novo cronômetro e invoca o cronômetro até ser interrompido. Você pode definir um atraso numérico no MS, mas é opcional, caso contrário, o padrão é zero. Se o tempo não for especificado, é considerado d3.now ().

timer.restart (callback [, delay [, time]])

Reinicie um cronômetro com o retorno de chamada especificado e atraso e tempo opcionais.

timer.stop ()

Este método interrompe o cronômetro, evitando retornos de chamada subsequentes.

d3.timeout (callback [, delay [, time]])

É usado para parar o cronômetro em seu primeiro retorno de chamada. O retorno de chamada é passado como o tempo decorrido.

d3.interval (callback [, delay [, time]])

Ele é chamado em um determinado intervalo de tempo. Se o atraso não for especificado, leva o tempo do cronômetro.

Exemplo

Crie uma página da web “timer.html” e adicione o seguinte script a ela.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3> Timer API </h3>
      <script>
         var timer = d3.timer(function(duration) {
            console.log(duration);
            if (duration > 150) timer.stop();
         }, 100);
      </script>
   </body>
</html>

Veremos a seguinte resposta na tela.

Vamos fazer um gráfico de barras animado neste capítulo. Para este exemplo, pegamos o arquivo data.csv usado no capítulo anterior dos registros de população como conjunto de dados e geramos um gráfico de barras animado.

Para fazer isso, precisamos realizar as seguintes etapas -

Step 1 - Apply styles - Aplique estilos CSS usando a codificação fornecida a seguir.

<style>
   .bar {
      fill: green;
   }
   
   .highlight {
      fill: red;
   }
   
   .title {
      fill: blue;
      font-weight: bold;
   }
</style>

Step 2 - Define variables - Vamos definir os atributos SVG usando o script abaixo.

<script>
   var svg = d3.select("svg"), margin = 200,
   width = svg.attr("width") - margin,
   height = svg.attr("height") - margin;
</script>

Step 3 - Append text - Agora, anexe o texto e aplique a transformação usando a codificação abaixo.

svg.append("text")
   .attr("transform", "translate(100,0)")
   .attr("x", 50)
   .attr("y", 50)
   .attr("font-size", "20px")
   .attr("class", "title")
   .text("Population bar chart")

Step 4 - Create scale range- Nesta etapa, podemos criar um intervalo de escala e anexar os elementos do grupo. É definido abaixo.

var x = d3.scaleBand().range([0, width]).padding(0.4),
   y = d3.scaleLinear()
      .range([height, 0]);
   var g = svg.append("g")
      .attr("transform", "translate(" + 100 + "," + 100 + ")");

Step 5 - Read data - Já criamos o data.csvarquivo em nossos exemplos anteriores. O mesmo arquivo que usamos aqui.

year,population
2006,40
2008,45
2010,48
2012,51
2014,53
2016,57
2017,62

Agora, leia o arquivo acima usando o código abaixo.

d3.csv("data.csv", function(error, data) {
   if (error) {
      throw error;
   }

Step 6 - Set domain - Agora, defina o domínio usando a codificação abaixo.

x.domain(data.map(function(d) { return d.year; }));
y.domain([0, d3.max(data, function(d) { return d.population; })]);

Step 7 - Add X-axis- Agora, você pode adicionar o eixo X à transformação. É mostrado abaixo.

g.append("g")
   .attr("transform", "translate(0," + height + ")")
   .call(d3.axisBottom(x)).append("text")
   .attr("y", height - 250).attr("x", width - 100)
   .attr("text-anchor", "end").attr("font-size", "18px")
   .attr("stroke", "blue").text("year");

Step 8 - Add Y-axis - Adicione o eixo Y à transformação usando o código fornecido a seguir.

g.append("g")
   .append("text").attr("transform", "rotate(-90)")
   .attr("y", 6).attr("dy", "-5.1em")
   .attr("text-anchor", "end").attr("font-size", "18px")
   .attr("stroke", "blue").text("population");

Step 9 - Append group elements - Agora, anexe os elementos do grupo e aplique a transformação ao eixo Y conforme definido abaixo.

g.append("g")
   .attr("transform", "translate(0, 0)")
   .call(d3.axisLeft(y))

Step 10 - Select the bar class - Agora, selecione todos os elementos na classe de barra conforme definido abaixo.

g.selectAll(".bar")
   .data(data).enter()
   .append("rect")
   .attr("class", "bar")
   .on("mouseover", onMouseOver) 
   .on("mouseout", onMouseOut)
   .attr("x", function(d) { return x(d.year); })
   .attr("y", function(d) { return y(d.population); })
   .attr("width", x.bandwidth())
   .transition()
   .ease(d3.easeLinear)
   .duration(200)
   .delay(function (d, i) {
      return i * 25;
   })
   .attr("height", function(d) { return height - y(d.population); });
});

Aqui, adicionamos o evento listener para o mouseout e o mouseover para executar a animação. Ele aplica a animação, quando o mouse passa sobre uma determinada barra e sai dela. Essas funções são explicadas na etapa a seguir.

o .ease(d3.easeLinear)função é usada para executar movimento aparente na animação. Ele processa o movimento lento e lento com uma duração de 200. O atraso pode ser calculado usando -

.delay(function (d, i) {
   return i * 25;
})

Step 11 - Mouseover event handler function - Vamos criar um manipulador de eventos mouseover para manipular um evento de mouse conforme mostrado abaixo.

function onMouseOver(d, i) {
   d3.select(this)
      .attr('class', 'highlight');
   d3.select(this)
      .transition()
      .duration(200)
      .attr('width', x.bandwidth() + 5)
      .attr("y", function(d) { return y(d.population) - 10; })
      .attr("height", function(d) { return height - y(d.population) + 10; });
   g.append("text")
      .attr('class', 'val') 
   
   .attr('x', function() {
      return x(d.year);
   })
   
   .attr('y', function() {
      return y(d.value) - 10;
   })
}

Aqui, no evento mouseover, queremos aumentar a largura e altura da barra e a cor da barra selecionada para vermelho. Para a cor, adicionamos um 'destaque' de classe, que muda a cor da barra selecionada para vermelho.

Uma função de transição para a barra com duração de 200 milissegundos. Quando aumentamos a largura da barra em 5 pixels e a altura em 10 pixels, a transição da largura e altura anteriores da barra para a nova largura e altura terá a duração de 200 milissegundos.

Em seguida, calculamos um novo valor 'y' para a barra, de modo que a barra não distorça devido ao novo valor de altura.

Step 12 - Mouseout event handler function- Vamos criar um manipulador de eventos mouseout para manipular um evento de mouse. É definido abaixo.

function onMouseOut(d, i) {
   d3.select(this).attr('class', 'bar');
   
   d3.select(this)
      .transition()     
      .duration(400).attr('width', x.bandwidth())
      .attr("y", function(d) { return y(d.population); })
      .attr("height", function(d) { return height - y(d.population); });
   
   d3.selectAll('.val')
      .remove()
}

Aqui, no evento mouseout, queremos remover os recursos de seleção que aplicamos no evento mouseover. Portanto, revertemos a classe da barra para a classe 'barra' original e restauramos a largura e a altura originais da barra selecionada e restauramos o valor y para o valor original.

o d3.selectAll(‘.val’).remove() A função é usada para remover o valor do texto que adicionamos durante a seleção da barra.

Step 13 - Working Example- O programa completo é fornecido no seguinte bloco de código. Crie uma página da webanimated_bar.html e adicione as seguintes alterações a ele.

<!DOCTYPE html>
<html>
   <head>
      <style>
         .bar {
            fill: green;
         }
        
         .highlight {
            fill: red;
         }
         
         .title {
            fill: blue;
            font-weight: bold;
         }
      </style>
      <script src = "https://d3js.org/d3.v4.min.js"></script>
      <title> Animated bar chart </title>
   </head>

   <body>
      <svg width = "500" height = "500"></svg>
      <script>
         var svg = d3.select("svg"),
         margin = 200, width = svg.attr("width") - margin,
         height = svg.attr("height") - margin;
         
         svg.append("text")
            .attr("transform", "translate(100,0)")
            .attr("x", 50).attr("y", 50)
            .attr("font-size", "20px")
            .attr("class", "title")
            .text("Population bar chart")
            
         var x = d3.scaleBand().range([0, width]).padding(0.4),
         y = d3.scaleLinear().range([height, 0]);
            
         var g = svg.append("g")
            .attr("transform", "translate(" + 100 + "," + 100 + ")");

         d3.csv("data.csv", function(error, data) {
            if (error) {
               throw error;
            }
               
            x.domain(data.map(function(d) { return d.year; }));
            y.domain([0, d3.max(data, function(d) { return d.population; })]);
                     
            g.append("g")
               .attr("transform", "translate(0," + height + ")")
               .call(d3.axisBottom(x))
               .append("text")
               .attr("y", height - 250)
               .attr("x", width - 100)
               .attr("text-anchor", "end")
               .attr("font-size", "18px")
               .attr("stroke", "blue").text("year");
               
            g.append("g")
               .append("text")
               .attr("transform", "rotate(-90)")
               .attr("y", 6)
               .attr("dy", "-5.1em")
               .attr("text-anchor", "end")
               .attr("font-size", "18px")
               .attr("stroke", "blue")
               .text("population");
                         
            g.append("g")
               .attr("transform", "translate(0, 0)")
               .call(d3.axisLeft(y))

            g.selectAll(".bar")
               .data(data)
               .enter()
               .append("rect")
               .attr("class", "bar")
               .on("mouseover", onMouseOver) 
               .on("mouseout", onMouseOut)   
               .attr("x", function(d) { return x(d.year); })
               .attr("y", function(d) { return y(d.population); })
               .attr("width", x.bandwidth()).transition()
               .ease(d3.easeLinear).duration(200)
               .delay(function (d, i) {
                  return i * 25;
               })
                  
            .attr("height", function(d) { return height - y(d.population); });
         });
          
          
         function onMouseOver(d, i) {
            d3.select(this)
            .attr('class', 'highlight');
               
            d3.select(this)
               .transition()     
               .duration(200)
               .attr('width', x.bandwidth() + 5)
               .attr("y", function(d) { return y(d.population) - 10; })
               .attr("height", function(d) { return height - y(d.population) + 10; });
              
            g.append("text")
               .attr('class', 'val')
               .attr('x', function() {
                  return x(d.year);
               })
               
            .attr('y', function() {
               return y(d.value) - 10;
            })
         }
          
         function onMouseOut(d, i) {
             
            d3.select(this)
               .attr('class', 'bar');
            
            d3.select(this)
               .transition()     
               .duration(200)
               .attr('width', x.bandwidth())
               .attr("y", function(d) { return y(d.population); })
               .attr("height", function(d) { return height - y(d.population); });
            
            d3.selectAll('.val')
               .remove()
         }
      </script>
   </body>
</html>

Agora, solicite o navegador e veremos a seguinte resposta.

Se selecionarmos qualquer barra, ela será destacada em vermelho. D3 é uma biblioteca de visualização de propósito geral que lida com a transformação de dados em informações, documentos, elementos, etc. e, em última análise, ajuda na criação de visualização de dados.