D3 Exploration - Step 1

D3入門學習1node

建立SVG容器

  • svg的相關內容: MDN

基本使用

const svg = d3
  .select('div') // other CSS Selectors~~
  .append("svg")
  .style({ 
    backgound: 'pink''
  })
  .attr("width", '80vw')
  .attr("height", '90vh');

效果:app

clipboard.png

封裝 D3Svg 類

用法

new D3Svg([opts]);
opts.xx 說明
container 裝載svg元素的容器元素,默認在body元素建立一個空的div容器
width svg容器的寬度
height svg容器的高度
style svg容器的樣式配置
wrapperContainerStyle 最外層容器的樣式配置
  • Creates and returns a svg element that is attached to elem. elem can be a DOM object or a selector.
  • The opts object will set the width and height of the svg if set, otherwise these attributes will remain null.
class D3Svg {

  private svg: d3.Selection<any>;
  private wrapperContainer: HTMLElement | HTMLDivElement;

  constructor(
    options: ISvgContainerOptions = {},
  ) {
    const container = options.container || DEFAULT_CONTAINER();
    const width = options.width || DEFAULT_CONTAINER_WIDTH;
    const height = options.options || DEFAULT_CONTAINER__HEIGHT;
    const { style, wrapperContainerStyle } = options;

    /**
     * initialize wrapperContainer
     */
    this.wrapperContainer = container;
    if (wrapperContainerStyle) {
      this.addWrapperStyle(wrapperContainerStyle);
    }
    this.svg = d3
      .select(this.wrapperContainer)
      .append("svg")
      .style({ ...style })
      .attr("width", width)
      .attr("height", height);
  }

  getSize(): IBoxSize {
    if (this.svg) {
      // Notice: it's SVGSVGElement
      const node = this.svg.node() as SVGSVGElement;
      const box = node.getBoundingClientRect();
      return box;
    }
    return {
      width: 0,
      height: 0,
    };
  }
  
  public addWrapperStyle(styles: { [key: string]: string }) {
    Object.keys(styles).map(key => {
      this.wrapperContainer.style.setProperty(key, styles[key]);
    });
  }
}

下一篇,開始添加咱們的圖像~~svg

相關文章
相關標籤/搜索