forked from fanruan/design
Browse Source
Merge in DESIGN/design from ~KERRY/design_10.0:release/10.0 to release/10.0 * commit '8c6d591ffb458fcdae72cc201340fa7c4204c55a': REPORT-31475 问题修复 REPORT-30739【10.0.6开接口】字体统一改成像素的可行性研究,及开接口feature/big-screen
kerry
5 years ago
10 changed files with 267 additions and 116 deletions
@ -0,0 +1,46 @@
|
||||
package com.fr.design.form.util; |
||||
|
||||
|
||||
import com.fr.design.ExtraDesignClassManager; |
||||
import com.fr.design.fun.FormAdaptiveConfigUIProcessor; |
||||
import com.fr.stable.Constants; |
||||
import com.fr.stable.unit.PT; |
||||
|
||||
|
||||
/** |
||||
* Created by kerry on 2020-04-16 |
||||
*/ |
||||
public class FontTransformUtil { |
||||
|
||||
/** |
||||
* 获取设计器字体显示dpi |
||||
* @return dpi |
||||
*/ |
||||
public static int getDesignerFontResolution() { |
||||
int dpi = Constants.FR_PAINT_RESOLUTION; |
||||
FormAdaptiveConfigUIProcessor adaptiveConfigUI = ExtraDesignClassManager.getInstance().getSingle(FormAdaptiveConfigUIProcessor.MARK_STRING); |
||||
if (adaptiveConfigUI != null) { |
||||
dpi = adaptiveConfigUI.fontResolution(); |
||||
} |
||||
return dpi; |
||||
} |
||||
|
||||
/** |
||||
* pt值转px |
||||
* @param value pt值 |
||||
* @return px值 |
||||
*/ |
||||
public static double pt2px(double value) { |
||||
return PT.pt2pix(value, getDesignerFontResolution()); |
||||
} |
||||
|
||||
/** |
||||
* px值转pt |
||||
* @param value px值 |
||||
* @return pt值 |
||||
*/ |
||||
public static double px2pt(double value) { |
||||
return value * (double) Constants.DEFAULT_FONT_PAINT_RESOLUTION / (double) getDesignerFontResolution(); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,68 @@
|
||||
package com.fr.design.form.util; |
||||
|
||||
import com.fr.design.ExtraDesignClassManager; |
||||
import com.fr.design.fun.FormAdaptiveConfigUIProcessor; |
||||
import com.fr.stable.Constants; |
||||
import org.easymock.EasyMock; |
||||
import org.junit.Assert; |
||||
import org.junit.Test; |
||||
import org.junit.runner.RunWith; |
||||
import org.powermock.api.easymock.PowerMock; |
||||
import org.powermock.core.classloader.annotations.PrepareForTest; |
||||
import org.powermock.modules.junit4.PowerMockRunner; |
||||
|
||||
/** |
||||
* Created by kerry on 2020-05-14 |
||||
*/ |
||||
@RunWith(PowerMockRunner.class) |
||||
@PrepareForTest(ExtraDesignClassManager.class) |
||||
public class FontTransformUtilTest { |
||||
|
||||
@Test |
||||
public void testGetDesignerFontResolution() { |
||||
mockEnvironment(Constants.DEFAULT_FONT_PAINT_RESOLUTION); |
||||
Assert.assertEquals(Constants.DEFAULT_FONT_PAINT_RESOLUTION, FontTransformUtil.getDesignerFontResolution()); |
||||
|
||||
mockEnvironment(Constants.DEFAULT_WEBWRITE_AND_SCREEN_RESOLUTION); |
||||
Assert.assertEquals(Constants.DEFAULT_WEBWRITE_AND_SCREEN_RESOLUTION, FontTransformUtil.getDesignerFontResolution()); |
||||
|
||||
} |
||||
|
||||
@Test |
||||
public void testPt2px() { |
||||
mockEnvironment(Constants.DEFAULT_FONT_PAINT_RESOLUTION); |
||||
Assert.assertEquals(12, (int) FontTransformUtil.pt2px(12)); |
||||
|
||||
mockEnvironment(Constants.DEFAULT_WEBWRITE_AND_SCREEN_RESOLUTION); |
||||
Assert.assertEquals(16, (int) FontTransformUtil.pt2px(12)); |
||||
} |
||||
|
||||
@Test |
||||
public void testPx2pt() { |
||||
mockEnvironment(Constants.DEFAULT_FONT_PAINT_RESOLUTION); |
||||
Assert.assertEquals(12, (int) FontTransformUtil.px2pt(12)); |
||||
|
||||
mockEnvironment(Constants.DEFAULT_WEBWRITE_AND_SCREEN_RESOLUTION); |
||||
Assert.assertEquals(9, (int) FontTransformUtil.px2pt(12)); |
||||
} |
||||
|
||||
|
||||
private void mockEnvironment(int dpi) { |
||||
ExtraDesignClassManager mockDesignManager = EasyMock.mock(ExtraDesignClassManager.class); |
||||
EasyMock.expect(mockDesignManager.getSingle(FormAdaptiveConfigUIProcessor.MARK_STRING)) |
||||
.andReturn(mockProcessor(dpi)).anyTimes(); |
||||
EasyMock.replay(mockDesignManager); |
||||
|
||||
PowerMock.mockStatic(ExtraDesignClassManager.class); |
||||
EasyMock.expect(ExtraDesignClassManager.getInstance()).andReturn(mockDesignManager).once(); |
||||
PowerMock.replayAll(ExtraDesignClassManager.class); |
||||
} |
||||
|
||||
private FormAdaptiveConfigUIProcessor mockProcessor(int dpi) { |
||||
FormAdaptiveConfigUIProcessor processor = EasyMock.mock(FormAdaptiveConfigUIProcessor.class); |
||||
EasyMock.expect(processor.fontResolution()).andReturn(dpi).once(); |
||||
EasyMock.replay(processor); |
||||
return processor; |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue