| |
| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| import { |
| subPixelOptimize, subPixelOptimizeLine, subPixelOptimizeRect |
| } from 'zrender/src/graphic/helper/subPixelOptimize'; |
| import { lineLineIntersect } from '@/src/util/graphic'; |
| |
| |
| describe('util/graphic', function () { |
| |
| describe('subPixelOptimize', function () { |
| |
| it('subPixelOptimize_base', function () { |
| expect(subPixelOptimize(5, 1)).toEqual(4.5); |
| expect(subPixelOptimize(5, 2)).toEqual(5); |
| expect(subPixelOptimize(5, 43)).toEqual(4.5); |
| expect(subPixelOptimize(7.5, 1)).toEqual(7.5); |
| expect(subPixelOptimize(7.5, 2)).toEqual(7); |
| expect(subPixelOptimize(14, 1, true)).toEqual(14.5); |
| expect(subPixelOptimize(14, 2, true)).toEqual(14); |
| expect(subPixelOptimize(-11, 1)).toEqual(-11.5); |
| expect(subPixelOptimize(-11, 2)).toEqual(-11); |
| expect(subPixelOptimize(0, 2)).toEqual(0); |
| expect(subPixelOptimize(0, 1)).toEqual(-0.5); |
| expect(subPixelOptimize(5, 0)).toEqual(5); |
| }); |
| |
| it('subPixelOptimize_line', function () { |
| function doSubPixelOptimizeLine(x: number, y: number, width: number, height: number, lineWidth: number) { |
| const params = makeParam(x, y, width, height, lineWidth); |
| return subPixelOptimizeLine(params.shape, params.shape, params.style); |
| } |
| function makeParam(x1: number, y1: number, x2: number, y2: number, lineWidth: number) { |
| return { |
| shape: {x1: x1, y1: y1, x2: x2, y2: y2}, |
| style: {lineWidth: lineWidth} |
| }; |
| } |
| expect(doSubPixelOptimizeLine(5, 11, 3, 7, 1)).toEqual(makeParam(5, 11, 3, 7, 1).shape); |
| expect(doSubPixelOptimizeLine(5, 11, 5, 7, 1)).toEqual(makeParam(5.5, 11, 5.5, 7, 1).shape); |
| expect(doSubPixelOptimizeLine(5, 11, 5, 7, 2)).toEqual(makeParam(5, 11, 5, 7, 2).shape); |
| expect(doSubPixelOptimizeLine(5, 11, 15, 11, 1)).toEqual(makeParam(5, 11.5, 15, 11.5, 1).shape); |
| expect(doSubPixelOptimizeLine(5, 11, 15, 11, 2)).toEqual(makeParam(5, 11, 15, 11, 2).shape); |
| expect(doSubPixelOptimizeLine(5, 11, 15, 11, 3)).toEqual(makeParam(5, 11.5, 15, 11.5, 3).shape); |
| expect(doSubPixelOptimizeLine(5, 11, 15, 11.5, 3)).toEqual(makeParam(5, 11, 15, 11.5, 3).shape); |
| expect(doSubPixelOptimizeLine(5, 11.5, 15, 11.5, 3)).toEqual(makeParam(5, 11.5, 15, 11.5, 3).shape); |
| expect(doSubPixelOptimizeLine(5, 11.5, 15, 11.5, 4)).toEqual(makeParam(5, 12, 15, 12, 4).shape); |
| }); |
| |
| it('subPixelOptimize_rect', function () { |
| function doSubPixelOptimizeRect(x: number, y: number, width: number, height: number, lineWidth: number) { |
| const params = makeParam(x, y, width, height, lineWidth); |
| return subPixelOptimizeRect(params.shape, params.shape, params.style); |
| } |
| function makeParam(x: number, y: number, width: number, height: number, lineWidth: number) { |
| return { |
| shape: {x: x, y: y, width: width, height: height}, |
| style: {lineWidth: lineWidth} |
| }; |
| } |
| expect(doSubPixelOptimizeRect(5, 11, 3, 7, 1)).toEqual(makeParam(5.5, 11.5, 2, 6, 1).shape); |
| expect(doSubPixelOptimizeRect(5, 11, 3, 7, 2)).toEqual(makeParam(5, 11, 3, 7, 2).shape); |
| expect(doSubPixelOptimizeRect(5, 11, 3, 7, 3)).toEqual(makeParam(5.5, 11.5, 2, 6, 3).shape); |
| // Boundary value tests |
| expect(doSubPixelOptimizeRect(5, 11, 1, 7, 1)).toEqual(makeParam(5.5, 11.5, 1, 6, 1).shape); |
| expect(doSubPixelOptimizeRect(5, 11, 1, 0, 1)).toEqual(makeParam(5.5, 11.5, 1, 0, 1).shape); |
| }); |
| |
| }); |
| |
| describe('lineLineIntersect', function () { |
| |
| it('extreme', function () { |
| expect(lineLineIntersect(10, 10, 30, 30, 10, 10, 10, 10)).toEqual(false); |
| }); |
| |
| it('parallel and colinear', function () { |
| expect(lineLineIntersect(10, 20, 30, 40, 100, 220, 120, 240)).toEqual(false); |
| expect(lineLineIntersect(10, 10, 30, 30, 40, 40, 50, 50)).toEqual(false); |
| expect(lineLineIntersect(10, 10, 30, 30, 10, 10, 30, 30)).toEqual(false); |
| expect(lineLineIntersect(10, 10, 30, 30, 20, 20, 30, 30)).toEqual(false); |
| expect(lineLineIntersect(10, 10, 30, 30, 20, 20, 22, 22)).toEqual(false); |
| }); |
| |
| it('intersect', function () { |
| expect(lineLineIntersect(10, 20, 30, 40, 12, 20, 30, 40)).toEqual(true); |
| expect(lineLineIntersect(10, 20, 30, 40, 12, 20, 20, 42)).toEqual(true); |
| }); |
| }); |
| |
| }); |