From c3140bc7ba519dfd4230936178b935567612c2e8 Mon Sep 17 00:00:00 2001 From: MiniPear Date: Wed, 27 Apr 2022 17:06:15 +0800 Subject: [PATCH] fix(band): using normalizedFlex to compute bandWidth and step (#184) --- __tests__/unit/scales/band.spec.ts | 21 +++++++++++++++++++++ package.json | 2 +- src/scales/band.ts | 4 ++-- 3 files changed, 24 insertions(+), 3 deletions(-) diff --git a/__tests__/unit/scales/band.spec.ts b/__tests__/unit/scales/band.spec.ts index ac01241..ae65731 100644 --- a/__tests__/unit/scales/band.spec.ts +++ b/__tests__/unit/scales/band.spec.ts @@ -182,6 +182,27 @@ describe('band scale', () => { expect(bandScale.map('C')).toBeCloseTo(416.67); }); + test('test non-normalized flex options', () => { + const bandScale = new Band({ + domain: ['A', 'B', 'C'], + flex: [20, 30, 10], + range: [0, 500], + }); + + const ba = bandScale.getBandWidth('A'); + const bb = bandScale.getBandWidth('B'); + const bc = bandScale.getBandWidth('C'); + expect([ba, bb, bc].map((d) => d / bc)).toEqual([2, 3, 1]); + + expect(bandScale.getStep('A')).toBeCloseTo(166.67); + expect(bandScale.getStep('B')).toBe(250); + expect(bandScale.getStep('C')).toBeCloseTo(83.33); + + expect(bandScale.map('A')).toBe(0); + expect(bandScale.map('B')).toBeCloseTo(166.67); + expect(bandScale.map('C')).toBeCloseTo(416.67); + }); + test('test patch flex options', () => { const bandScale = new Band({ domain: ['A', 'B', 'C'], diff --git a/package.json b/package.json index 09b36cb..6075ee5 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@antv/scale", - "version": "0.4.7", + "version": "0.4.8", "description": "Toolkit for mapping abstract data into visual representation.", "license": "MIT", "main": "lib/index.js", diff --git a/src/scales/band.ts b/src/scales/band.ts index 291f97f..7fe11d6 100644 --- a/src/scales/band.ts +++ b/src/scales/band.ts @@ -76,13 +76,13 @@ function computeBandState(options: BandStateOptions) { // 计算每个 bandWidth 和 step,并且用定义域内的值索引 const valueBandWidth = new Map( domain.map((d, i) => { - const bandWidth = flex[i] * minBandWidth; + const bandWidth = normalizedFlex[i] * minBandWidth; return [d, round ? Math.floor(bandWidth) : bandWidth]; }) ); const valueStep = new Map( domain.map((d, i) => { - const bandWidth = flex[i] * minBandWidth; + const bandWidth = normalizedFlex[i] * minBandWidth; const step = bandWidth + PI; return [d, round ? Math.floor(step) : step]; })