[x3d-public] draft X3D 4.1 prose for font files and libraries DEF/USE

Joe D Williams joedwil at earthlink.net
Sat Mar 15 14:28:20 PDT 2025


> References to the FontLibrary are made from FontStyle.
> Fontstyle adds a node called LibraryFontthat can (has to) USE a FontLibrary node.

OK, FontLibrary can contain a url in the standard x3d form 
with enough information to pick a font for the current FontStyle.  
This is risky since the library has to respond in the same way as 
a default FontStyle, as if it were stock built-in. 

...     
No, Please. That is too simple. 
If the author/user wants a font from an external source  
then, for best safety and security, access must be through  
a specific LibraryFont node. 
    
So, the only 'standard' use for 'external' not built-in font is: 
There must be a FontLibrary node that defines the 
external font file location and contents. 
The FontStyle.LibraryFont node refers to the 
FontLibrary and other FontStyle parameters 
to apply for production of Text string. 
    
It is important that LibraryFont includes enough information 
about its contents to apply the correct choice for the 
current FontStyle parameters. 
Using an external file must work in the same way 
as stock built-in default Text node and any fail falls back 
to built-in font with guidance from FontStyle. . 
   
Thanks and Best, 
Joe
   




    




Ideally only the url would be provided and the FontStylefields wouldeused. 
If the FontLibrary includes all parameters ofthesamefieldsareusedin

FontLibrary 
 url 
 name         "sfstring"
 language  [mfstring]
 family        "sfstring"
 style          [mfstring]

same list of parameters as LibraryFont  



-----Original Message-----
From: Joe D Williams <joedwil at earthlink.net>
Sent: Mar 14, 2025 9:27 PM
To: Extensible 3D (X3D) Graphics public discussion <x3d-public at web3d.org>
Cc: Joe D Williams <joedwil at earthlink.net>, Andreas Plesch <andreasplesch at gmail.com>, <yottzumm at gmail.com>
Subject: Re: [x3d-public] draft X3D 4.1 prose for font files and libraries DEF/USE

> FontLibrary : X3DNode, X3DUrlObject {

To add a library concept we need to add
a url
and a name
and lists of contained language, family, and style.

If library can be a Node, then along with the url and name,
maybe meta to include lists for language, family and style.
Now we need another node to help FontStyle.

Getting this right is proof we might be able to figure out
how to declare a non-rendering asset and use it later
in that scene.
This is all a style thing, by and for the family.
Proto does that but this non-rendering "Library" concrete Node
that can be used later is something that has been tried but
never made a standards-track.appearance.

FontLibrary node has a DEF and includes
information for url, name language family style data
There must be enough file description so at authortime
reasonable checks can be made that references to that
node are valid. So, required meta for FontLibrary must include
available font names, languages, families, and styles.

References to the FontLibrary are made from FontStyle.
Fontstyle adds a node called LibraryFont
that can (has to) USE a FontLibrary node.

FontLibrary DEF MyFont
url
name
language(s)
family
style(s)
...
FontStyle ...
language
family
style
LibraryFont USE MyFont

Right, in order to use an external font file it has
to be defined in a FontLibary node and
referenced in FontStyle

The application must use the FontStyle parameters
language, family, style in addition to the url and name
in the FontLibrary node to apply the correct font from
the library.

So, That could be sort of like one of the examples.

Thanks and Best,
Joe.



-----Original Message-----
From: Extensible 3D (X3D) Graphics public discussion
Sent: Mar 14, 2025 10:31 AM
To: Extensible 3D (X3D) Graphics public discussion , Extensible 3D (X3D) Graphics public discussion
Cc: Joe D Williams , Andreas Plesch
Subject: Re: [x3d-public] draft X3D 4.1 prose for font files and libraries

I have finally studied this and have some thoughts that are taking som time to organize.

>is scoped to the current model
... scoped to the current execution context.
maybe talking between root and other context(s) using import/export
This means scoped same as inline or proto or layer?
Same as inline or proto/protoinstance, layers, other?
shared from LayerSet?


The fontLibrary field can contain a single FontLibrary node that may provide a font matching a value in the list of allowed family values.
Do we really need to add this field? Subject to mailing list discussion, we expect to delete the family field

I don't understand this strike and question. The examples and some markup do not seem to match either intent.

> we expect to delete the family field

deprecate? should have a great reason to do that, please tell
FontStyle : X3DFontStyleNode { SFNode [in,out] metadata NULL [X3DMetadataObject] MFString [] family "SERIF"FontLibrary : X3DNode, X3DUrlObject {

If needed, Please make this a node that I want to DEF at the highest level and
USE data from it in Text node(s) wherever in that scene it is legal.

We need the concept of a library that is clearly defined
and content can be at tested in AuthorTime.

To add a library concept we need to add
a url
and a name
and lists of contained language, family, and style.

The example 2 does not imply a 'global' library.
the example 1 implies a 'global' library but dumps on Fontstyle

Example: For X3D, for USD it is likely that an indexed library will be
available as essentially a 'global' asset that can be referenced from
anywhere in the - well, the audio manifest - how do they call it?
Anyway, the current url form could include a url with a set of
parameters that specify a certain file in a library.
But that would be a complicated url because
language, family, and style would need to be included.
Maybe by metadata?

Not really complete thoughts,
Joe







-----Original Message-----
From: Extensible 3D (X3D) Graphics public discussion
Sent: Mar 14, 2025 8:27 AM
To: Extensible 3D (X3D) Graphics public discussion
Cc: John Carlson , Andreas Plesch
Subject: Re: [x3d-public] draft X3D 4.1 prose for font files and libraries

Or alternatively, provide a cssStyle attribute/field. Another idea would be to add a css class in the family field??? Maybe one could support both FontStyle.url and css support? Hmm! John
On Fri, Mar 14, 2025 at 10:12 AM John Carlson wrote:I don’t have a clue on why FontStyle.url is insufficient, except that some font urls have more than one font. Perhaps all that is needed is providing more values to existing FontStyle fields, and gracefully hide most of the ugly, complicated stuff. Perhaps it would be best to provide a registry of fonts separate from the standards? Maybe even with component levels? Really, this conversation started with me asking about CSS fonts. How about adding CSS styles to FontStyle??? That is, provide a way to include a CSS file, perhaps with Inline? Or just use existing style attribute? Hmm! John On Fri, Mar 14, 2025 at 5:41 AM Michalis Kamburelis via x3d-public wrote:
I still have not heard a convincing argument why a more
straightforward "FontStyle.url" was rejected. "FontStyle.url" seems
like a straightforward solution that avoids all the pitfalls of
"FontLibrary", because the association between FontStyle font file
is just explicit.







More information about the x3d-public mailing list