當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript d3.max函數代碼示例

本文整理匯總了TypeScript中d3.max函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript max函數的具體用法?TypeScript max怎麽用?TypeScript max使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了max函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: max

    public max(name?: string): number {
        var matrix: IDatum[][] = [];

        if (name != undefined && name != "" && this._chart.stackType === StackType.None) {
            matrix = this.getMatricesByAxisName(name);
        }

        if (matrix.length === 0) {
            matrix = this._matrix;
        }

        if (this._chart.stackType != StackType.None && this.items.length > 1) { // can only be stacked if you have more than 1 series defined
            return d3.max(matrix, function (array: IDatum[]): number {
                return d3.max(array, function (d: IDatum): number {
                    return d.sum;
                });
            });
        }
        else {
            return d3.max(matrix, function (array: IDatum[]): number {
                return d3.max(array, function (d: IDatum): number {
                    if (d.y != undefined && d.y > d.y1) {
                        return d.y;
                    }
                    return d.y1;
                });
            });
        }
    }
開發者ID:frnkclsst,項目名稱:d3charts,代碼行數:29,代碼來源:Series.ts

示例2: draw

    private draw(): void {
        var xMin = d3.min(this._points, p => p[0]);
        var xMax = d3.max(this._points, p => p[0]);
        var yMin = d3.min(this._points, p => p[1]);
        var yMax = d3.max(this._points, p => p[1]);

        var lineGenerator = d3.svg.line()
            .x(d => this._scale(d[0]))
            .y(d => this._scale(d[1]));
        var path = this._group
            .append('path')
            .attr('d', lineGenerator(this._points))
            .attr({
                fill: this._color
            });
        this._group
            .append('text')
            .attr({
                'transform': `translate(${this._scale((xMax + xMin) / 2)},${this._scale((yMax + yMin) / 2)})`
            })
            .style({
                'text-transform': 'uppercase',
                'text-anchor': 'middle'
            })
            .text(this._name);
    }
開發者ID:Ledragon,項目名稱:HousePlan,代碼行數:26,代碼來源:room.ts

示例3: update

    public update(data: any[]) {
        let propertyKey = this.config.get('propertyKey'),
            propertyX = this.config.get('propertyX'),
            propertyY = this.config.get('propertyY'),
            ticks = this.config.get('bins'),
            x = this.x.xAxis.scale(),
            y = this.y.yAxis.scale(),
            height = this.config.get('height'),
            width = this.config.get('width');

        let histogramData = data.map((d) => d[propertyX]);

        let bins = histogram()
            .domain(x.domain())
            .thresholds(x.ticks(ticks))
            (histogramData);

        this.bins = bins;

        this.y.updateDomainByMinMax(0, max(bins, (d) => d.length));
        this.y.transition();

        this.x.updateDomainByMinMax(
            min(data, (d) => d[propertyX]),
            max(data, (d) => d[propertyX] + (bins[0].x1 - bins[0].x0))
        );

        this.x.transition();

        // JOIN bars
        let bars = this.svg.selectAll('.proteic-bars').selectAll('.' + Globals.SELECTOR_ELEMENT)
            .data(bins);

        // Update bars
        this.elementUpdate = bars;

        // Enter bars
        this.elementEnter = bars
            .enter().append('rect')
            .attr('class', Globals.SELECTOR_ELEMENT)
            .attr('data-proteic-element', 'barHistogram')
            .attr('x', (d) => x(d.x0))
            .attr('y', (d) => y(d.length))
            .attr('width', x(bins[0].x1) - x(bins[0].x0) - 1)
            .attr('height', (d) => height - y(d.length));

        this.elementExit = bars.exit().remove();

        bars
            .on('mousedown.user', this.config.get('onDown'))
            .on('mouseup.user', this.config.get('onUp'))
            .on('mouseleave.user', this.config.get('onLeave'))
            .on('mouseover.user', this.config.get('onHover'))
            .on('click.user', this.config.get('onClick'));
    }
開發者ID:proteus-h2020,項目名稱:proteus-charts,代碼行數:55,代碼來源:HistogramBarset.ts

示例4: boundingBox

  // Compute a minimum bounding box for a supplied collection of boxes.
  static boundingBox(...boxes: Box[]): Box {
    if (_.isEmpty(boxes)) {
      return null;
    }

    const left = d3.min(boxes, b => b.left());
    const top = d3.min(boxes, b => b.top());
    const right = d3.max(boxes, b => b.right());
    const bottom = d3.max(boxes, b => b.bottom());
    return new Box(left, top, right - left, bottom - top);
  }
開發者ID:a6802739,項目名稱:cockroach,代碼行數:12,代碼來源:zoom.ts

示例5: function

        d3.tsv("app/components/bar-charts-simple-bar-chart/data.tsv", type, function(error, data) {
        if (error) throw error;

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

        svg.append("g")
            .attr(attrName, "")
            .attr("class", "x axis")
            .attr("transform", "translate(0," + height + ")")
            .call(xAxis);

        svg.append("g")
            .attr(attrName, "")
            .attr("class", "y axis")
            .call(yAxis)
            .append("text")
            .attr(attrName, "")
            .attr("transform", "rotate(-90)")
            .attr("y", 6)
            .attr("dy", ".71em")
            .style("text-anchor", "end")
            .text("Frequency");

        svg.selectAll(".bar")
            .data(data)
            .enter().append("rect")
            .attr(attrName, "")
            .attr("class", "bar")
            .attr("x", function(d) { return x(d.letter); })
            .attr("width", x.rangeBand())
            .attr("y", function(d) { return y(d.frequency); })
            .attr("height", function(d) { return height - y(d.frequency); });
        });
開發者ID:Anhmike,項目名稱:angular2-d3-sample,代碼行數:34,代碼來源:simple-bar-chart.ts

示例6: ngOnInit

	ngOnInit() {
		const data = [
			{name: "First", value: 4}, 
			{name: "Second", value: 8}, 
			{name: "Third", value: 15}, 
			{name: "Fourth", value: 16}, 
			{name: "Fifth", value: 23}, 
			{name: "Sixth", value: 42}];

		const margin = {top: 20, right: 30, bottom: 30, left: 40},
			width = 960 - margin.left - margin.right,
			height = 500 - margin.top - margin.bottom;

		const x = d3.scale.ordinal()
			.domain(data.map(function(d) { return d.name; }))
			.rangeRoundBands([0, width], .1);

		const y = d3.scale.linear()
			.domain([0, d3.max(data, function(d) { return d.value; })])
			.range([height, 0]);

		const xAxis = d3.svg.axis()
			.scale(x)
			.orient("bottom");

		const yAxis = d3.svg.axis()
			.scale(y)
			.orient("left");

		const chart = d3.select(".chart")
			.attr("width", width + margin.left + margin.right)
			.attr("height", height + margin.top + margin.bottom)
		.append("g")
			.attr("transform", "translate(" + margin.left + "," + margin.top + ")");

		chart.append("g")
			.attr("class", "x axis")
			.attr("transform", "translate(0," + height + ")")
			.call(xAxis);

		chart.append("g")
			.attr("class", "y axis")
			.call(yAxis)
			.append("text")
			.attr("transform", "rotate(-90)")
			.attr("y", 6)
			.attr("dy", ".71em")
			.style("text-anchor", "end")
			.text("Frequency");

		chart.selectAll(".bar")
			.data(data)
			.enter().append("rect")
			.attr("class", "bar")
			.attr("x", function(d) { return x(d.name); })
			.attr("y", function(d) { return y(d.value); })
			.attr("height", function(d) { return height - y(d.value); })
			.attr("width", x.rangeBand());
	}
開發者ID:TiagoJSM,項目名稱:Angular2_D3,代碼行數:59,代碼來源:bar-chart.component.ts

示例7: function

 return d3.max(matrix, function (array: IDatum[]): number {
     return d3.max(array, function (d: IDatum): number {
         if (d.y != undefined && d.y > d.y1) {
             return d.y;
         }
         return d.y1;
     });
 });
開發者ID:frnkclsst,項目名稱:d3charts,代碼行數:8,代碼來源:Series.ts

示例8: render

  render() {

    if (!this.data && this.data.length === 0) {
      return;
    }

    this.xScale
      .domain(this.data.map(d => d.label))
      .rangeRoundBands([0, this.chartWidth], .1);

    this.yScale
      .domain([0, d3.max(this.data, d => d.value)])
      .range([this.chartHeight, 0]);

    this.xAxisElement.attr('transform', `translate(0, ${this.chartHeight})`);
    //this.yGridElement.call(this.yGrid.tickSize(-this.chartWidth, 0, 0));

    this.xAxis.scale(this.xScale);
    this.yAxis.scale(this.yScale);

    this.xAxisElement.transition().call(this.xAxis);
    this.yAxisElement.transition().call(this.yAxis);

    let bars = this.barElement
      .selectAll('.bar')
      .data(this.data);

    /************************************************************
     * D3 Enters
     ***********************************************************/

    bars.enter()
      .append('rect')
      .attr('class', 'bar')
      .style('fill', d => this.color(d.label))
      .attr('x', d => this.xScale(d.label))
      .attr('width', this.xScale.rangeBand())
      .attr('y', d => this.yScale(d.value))
      .attr('height', d => this.chartHeight - this.yScale(d.value));

    /************************************************************
     * D3 Transitions
     ***********************************************************/

    bars.transition()
      .attr('x', d => this.xScale(d.label))
      .attr('width', this.xScale.rangeBand())
      .attr('y', d => this.yScale(d.value))
      .attr('height', d => this.chartHeight - this.yScale(d.value));

    //arcs.transition().attr('d', d => this.pie(d.data));

    /************************************************************
     * D3 Exits
     ***********************************************************/
    bars.exit().transition().remove();
  }
開發者ID:brewday,項目名稱:waterprofile,代碼行數:57,代碼來源:bar-chart.component.ts

示例9: it

    it("line", () => {
      const text = "helloworld";
      const dimensions = measurer.measure(text);
      const characterDimensions: IDimensions[] = text.split("").map((c) => measurer.measure(c));
      const dimensionsByCharacter = {
        height: d3.max(characterDimensions.map((c) => c.height)),
        width: d3.sum(characterDimensions.map((c) => c.width)),
      };

      assert.deepEqual(dimensions, dimensionsByCharacter, "text has been measured by characters.");
    });
開發者ID:palantir,項目名稱:svg-typewriter,代碼行數:11,代碼來源:measurerTests.ts

示例10: getXScale

    public getXScale(axis: Axis): d3.scale.Linear<number, number> {
        var min = d3.min(this.series.items[0].data);
        var max = d3.max(this.series.items[0].data);
        var start = this.canvas.plotArea.axisSize.left;
        var end =  this.canvas.plotArea.axisSize.left + this.canvas.plotArea.width;

        axis.setScaleType(ScaleType.Linear);
        return d3.scale.linear()
            .domain([min < 0 ? min : 0, max])
            .nice() // adds additional ticks to add some whitespace
            .range([start, end]);
    }
開發者ID:frnkclsst,項目名稱:d3charts,代碼行數:12,代碼來源:ScatterChart.ts


注:本文中的d3.max函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。