Flex - Flash Builder 设计视图未正确显示嵌入字体

发布于 2024-10-07 14:39:47 字数 1305 浏览 12 评论 0原文

工具:Air 2、Flex SDK 4.1、Flash Builder、Halo 组件集(根本没有使用 Spark)

字体在运行应用程序时完美运行,但在设计视图中则不然。这实际上使设计视图变得无价值,因为在不知道真实大小的情况下不可能正确定位组件或标签(它会根据字体而变化......)

...

根组件中包含 CSS,如下所示:

<fx:Style source="style.css"/>

CSS 文件:

/* CSS file */
@namespace mx "library://ns.adobe.com/flex/mx";

global {
    font-family:Segoe;
    font-size:14;
    color:#FFFFFF;
}

mx|Application, mx|VBox, mx|HBox, mx|Canvas {
    font-family:Segoe;
    background-color:#660000;
    border-color:#222277;
    color:#FFFFFF;
}

mx|Button {
    font-family:Segoe;
    fill-colors:#660000, #660000, #660000, #660000;
    color:#FFFFFF;
}
...

有趣的是(或者有问题?),当我尝试将样式标签粘贴到子组件(低于顶级容器)时,我在子组件编辑器视图中收到一堆警告,指出不支持 CSS 类型选择器。 .(样式表中的所有组件)。
然而,当应用程序执行时,它们确实起作用。啊?

这就是我将字体嵌入到 root 级别容器中的方式:

 [Embed(source="/assets/segoepr.ttf", fontName="Segoe", mimeType="application/x-font-truetype", embedAsCFF='false')]
 public static const font:Class;

 [Embed(source="/assets/segoeprb.ttf", fontName="Segoe", mimeType="application/x-font-truetype", fontWeight="bold", embedAsCFF='false')]
 public static const font2:Class;

那么,有没有办法让嵌入的字体在设计视图中工作或者什么?

Tools: Air 2, Flex SDK 4.1, Flash Builder, Halo component set (NO Spark being used at all)

Fonts work perfectly when running the appliction, but not in design view. This effectively makes design view WORTHLESS because it's impossible to properly position components or labels without knowing what the true size is (it changes depending on font...)

...

CSS included in root component like so:

<fx:Style source="style.css"/>

CSS file:

/* CSS file */
@namespace mx "library://ns.adobe.com/flex/mx";

global {
    font-family:Segoe;
    font-size:14;
    color:#FFFFFF;
}

mx|Application, mx|VBox, mx|HBox, mx|Canvas {
    font-family:Segoe;
    background-color:#660000;
    border-color:#222277;
    color:#FFFFFF;
}

mx|Button {
    font-family:Segoe;
    fill-colors:#660000, #660000, #660000, #660000;
    color:#FFFFFF;
}
...

Interestingly (or buggily?), when I try pasting the style tag into a subcomponent (lower than the top level container), I get a bunch of warnings in the subcomponent editor view stating that CSS type selectors are not supported in.. (all the components in the style sheet).
Yet, they do work when the application is executed. Huh?

This is how I'm embedding the fonts in the root level container:

 [Embed(source="/assets/segoepr.ttf", fontName="Segoe", mimeType="application/x-font-truetype", embedAsCFF='false')]
 public static const font:Class;

 [Embed(source="/assets/segoeprb.ttf", fontName="Segoe", mimeType="application/x-font-truetype", fontWeight="bold", embedAsCFF='false')]
 public static const font2:Class;

So, is there a way to get embedded fonts to work in design view or what?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

誰ツ都不明白 2024-10-14 14:39:47

我不知道这是否有帮助,但值得一试。如果您使用的是 css,则无需使用 Embed Meta 标签嵌入字体。尝试删除字体类嵌入并在 css 文件中添加嵌入。这可能与 Flex 中的设计视图配合得更好。

// using system font
@font-face {
    src: local("Myriad Web Pro");
    fontFamily: myFontFamily;
    advancedAntiAliasing: true;
}

// using url to font file
@font-face {
    src: url("../assets/MyriadWebPro.ttf");
    fontFamily: myFontFamily;
    advancedAntiAliasing: true;
}

在设计视图中尝试以下代码:

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
               xmlns:s="library://ns.adobe.com/flex/spark" 
               xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">

    <fx:Style>
        @namespace s "library://ns.adobe.com/flex/spark";
        @namespace mx "library://ns.adobe.com/flex/mx";

        @font-face {
            src: url("Arial Bold.ttf");
            fontFamily: "Arial Bold";
            embedAsCff: true;
        }


        s|Application
        {
            color: #000000;
            fontFamily: "Arial Bold";
            font-size: 48;
        }

    </fx:Style>

    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>

    <s:Label text="This is the first label" width="488"  x="43" y="39" height="54"/>
    <s:Label text="This is the second label" width="488"  x="45" y="129" height="54" rotation="-4"/>
    <s:Label text="This is the third label" width="488"  x="43" y="208" height="54"/>

</s:Application>

I dont know if this helps but it is worth a shot. You don´t need to embed the fonts with the Embed Meta tag if you are using css. Try removing the font class embedding and add the embedding in the css file. This may work better with the design view in Flex.

// using system font
@font-face {
    src: local("Myriad Web Pro");
    fontFamily: myFontFamily;
    advancedAntiAliasing: true;
}

// using url to font file
@font-face {
    src: url("../assets/MyriadWebPro.ttf");
    fontFamily: myFontFamily;
    advancedAntiAliasing: true;
}

Try this code in design view:

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
               xmlns:s="library://ns.adobe.com/flex/spark" 
               xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">

    <fx:Style>
        @namespace s "library://ns.adobe.com/flex/spark";
        @namespace mx "library://ns.adobe.com/flex/mx";

        @font-face {
            src: url("Arial Bold.ttf");
            fontFamily: "Arial Bold";
            embedAsCff: true;
        }


        s|Application
        {
            color: #000000;
            fontFamily: "Arial Bold";
            font-size: 48;
        }

    </fx:Style>

    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>

    <s:Label text="This is the first label" width="488"  x="43" y="39" height="54"/>
    <s:Label text="This is the second label" width="488"  x="45" y="129" height="54" rotation="-4"/>
    <s:Label text="This is the third label" width="488"  x="43" y="208" height="54"/>

</s:Application>
碍人泪离人颜 2024-10-14 14:39:47

默认情况下,标签和文本区域似乎需要使用 Verdana 字体,如果我们不嵌入它,则设计视图不会考虑任何其他嵌入字体。

请嵌入 Verdana 字体,您应该能够在设计视图中看到标签和文本区域。

@font-face {
    src: local("Verdana");
    font-family: verdana;
    font-weight: normal;
}

希望这有帮助。

It seems that the font Verdana is expected for Label and Text areas by default and if we do not embed it, the design view does not take any other embedded fonts in consideration.

Please embed the Verdana font and you should be able to see the labels and text areas in design view.

@font-face {
    src: local("Verdana");
    font-family: verdana;
    font-weight: normal;
}

Hope this helps.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文