diff --git a/packages/f2/src/components/pictorial/pictorial.tsx b/packages/f2/src/components/pictorial/pictorial.tsx index 16fe55785..2f943ea87 100644 --- a/packages/f2/src/components/pictorial/pictorial.tsx +++ b/packages/f2/src/components/pictorial/pictorial.tsx @@ -2,76 +2,20 @@ import { jsx } from '@antv/f-engine'; import { GeometryProps } from '../geometry'; import { withInterval } from '../interval'; import { DataRecord } from '../../chart/Data'; -import { deepMix } from '@antv/util'; - -const parsePercent = (value: number | string, total: number) => { - if (typeof value === 'number') { - return value; - } else if (typeof value === 'string') { - if (value.endsWith('%')) { - return (parseFloat(value) / 100) * total; - } else { - return 0; - } - } -}; - export interface PictorialProps extends GeometryProps { symbol?: any; - symbolSize?: (number | string)[]; - symbolOffset?: (number | string)[]; } export default class Pictorial extends withInterval({}) { props: PictorialProps; - // 默认初始大小 - symbolDefaultSize: number = 400; - - defalutBound(type) { - switch (type) { - case 'ellipse': - return { - rx: this.symbolDefaultSize / 2, - ry: this.symbolDefaultSize / 2, - }; - - default: - return { - width: this.symbolDefaultSize, - height: this.symbolDefaultSize, - }; - } - } - - preSymbolBound(symbol) { - symbol.props = deepMix( - { - style: this.defalutBound(symbol?.type), - }, - symbol.props - ); - - return { - width: this.symbolDefaultSize, - height: this.symbolDefaultSize, - }; - } - - parsePercentArray(array, [w, h]) { - const x = parsePercent(array[0], w); - const y = parsePercent(array[1], h); - return [x, y]; - } render() { const { props, context } = this; const { px2hd } = context; - const { symbol, symbolSize = ['100%', '100%'], symbolOffset = [0, 0] } = px2hd(props); + const { symbol: Symbol } = px2hd(props); const records = this.mapping(); - const { width: symbolW, height: symbolH } = this.preSymbolBound(symbol); - return ( {records.map((record) => { @@ -79,26 +23,8 @@ export default class Pictorial extends withInterval({}) { return ( {children.map((item) => { - const [width, height] = this.parsePercentArray(symbolSize, [ - item.xMax - item.xMin, - item.yMax - item.yMin, - ]); - const [offsetX, offsetY] = this.parsePercentArray(symbolOffset, [width, height]); - const position = [item.xMin + offsetX, item.yMin + offsetY]; - - const symbolScale = [width / symbolW, height / symbolH]; - const transform = `translate(${position[0]},${position[1]}) scale(${symbolScale[0]},${symbolScale[1]})`; - - return deepMix( - { - props: { - style: { - transform, - }, - }, - }, - symbol - ); + const { xMax, xMin, yMax, yMin } = item; + return ; })} ); diff --git a/packages/f2/test/components/pictorial/basic.test.tsx b/packages/f2/test/components/pictorial/basic.test.tsx index b730e2386..c7b6bfe9d 100644 --- a/packages/f2/test/components/pictorial/basic.test.tsx +++ b/packages/f2/test/components/pictorial/basic.test.tsx @@ -3,42 +3,14 @@ import { Canvas, Chart, Pictorial, Axis, Tooltip } from '../../../src'; import { createContext, delay, gestureSimulator } from '../../util'; const context = createContext(); -const symbol = ( - -); - -const symbolTop = ( - -); - -const symbolBottom = ( - -); const data = [ { x: '产品1', value: 4927, - bValue: 0, }, { x: '产品2', value: 11607, - bValue: 0, }, ]; @@ -49,21 +21,43 @@ describe('pictorial', () => { - - - ( + + + + + + )} /> @@ -81,45 +75,41 @@ describe('pictorial', () => { - - - } - symbolOffset={['50%', 0]} - symbolSize={['100%', '40px']} - /> - - - } - /> - } - symbolSize={['100%', '40px']} - symbolOffset={['50%', 0]} + symbol={({ xMin, xMax, yMin, yMax, width, height, origin }) => ( + + + + + + )} />