From: Simon Steiner Date: Mon, 16 Jan 2023 14:07:18 +0000 (+0000) Subject: FOP-3114: Font size was rounded to 0 for AFP TTF X-Git-Tag: 2_9~41 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=e1e6d307087be2132de6d5e64599580e44a6c335;p=xmlgraphics-fop.git FOP-3114: Font size was rounded to 0 for AFP TTF git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@1906708 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/fop-core/src/main/java/org/apache/fop/afp/modca/ActiveEnvironmentGroup.java b/fop-core/src/main/java/org/apache/fop/afp/modca/ActiveEnvironmentGroup.java index ce4825a05..034e26861 100644 --- a/fop-core/src/main/java/org/apache/fop/afp/modca/ActiveEnvironmentGroup.java +++ b/fop-core/src/main/java/org/apache/fop/afp/modca/ActiveEnvironmentGroup.java @@ -196,7 +196,7 @@ public final class ActiveEnvironmentGroup extends AbstractEnvironmentGroup { mdr.addTriplet(new FontFullyQualifiedNameTriplet((byte) fontRef)); setupTruetypeMDR(mdr, false); - mdr.addTriplet(new DataObjectFontTriplet(size / 1000)); + mdr.addTriplet(new DataObjectFontTriplet(size / 1000f)); mdr.finishElement(); } else { if (mapCodedFont == null) { @@ -248,9 +248,9 @@ public final class ActiveEnvironmentGroup extends AbstractEnvironmentGroup { } static class DataObjectFontTriplet extends AbstractTriplet { - private int pointSize; + private float pointSize; - public DataObjectFontTriplet(int size) { + public DataObjectFontTriplet(float size) { super(DATA_OBJECT_FONT_DESCRIPTOR); pointSize = size; } @@ -262,7 +262,7 @@ public final class ActiveEnvironmentGroup extends AbstractEnvironmentGroup { public void writeToStream(OutputStream os) throws IOException { byte[] data = getData(); data[3] = 0x20; - byte[] pointSizeBytes = BinaryUtils.convert(pointSize * 20, 2); + byte[] pointSizeBytes = BinaryUtils.convert(Math.round(pointSize * 20), 2); data[4] = pointSizeBytes[0]; //vfs data[5] = pointSizeBytes[1]; // data[6] = pointSizeBytes[0]; //hsf diff --git a/fop-core/src/test/java/org/apache/fop/afp/modca/ActiveEnvironmentGroupTestCase.java b/fop-core/src/test/java/org/apache/fop/afp/modca/ActiveEnvironmentGroupTestCase.java new file mode 100644 index 000000000..b44d4b7fd --- /dev/null +++ b/fop-core/src/test/java/org/apache/fop/afp/modca/ActiveEnvironmentGroupTestCase.java @@ -0,0 +1,33 @@ +/* + * 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. + */ + +/* $Id$ */ +package org.apache.fop.afp.modca; + +import java.io.ByteArrayOutputStream; + +import org.junit.Assert; +import org.junit.Test; + +public class ActiveEnvironmentGroupTestCase { + @Test + public void testDataObjectFontTriplet() throws Exception { + ByteArrayOutputStream bos = new ByteArrayOutputStream(); + new ActiveEnvironmentGroup.DataObjectFontTriplet(0.5f).writeToStream(bos); + Assert.assertEquals(bos.toByteArray()[5], 10); + } +}