'Segoe UI' font with font-face & local

后端 未结 3 459
旧巷少年郎
旧巷少年郎 2020-12-28 16:35

I want to use the \"Segoe UI\" font in a website if it is installed in the user\'s computer.

I have declared all the styles with @font-face in order to

相关标签:
3条回答
  • 2020-12-28 16:57

    Although the basic approach is logical, browsers seem to have difficulties with it, apparently caused by their different processing of font data. It seems that the following is the most effective way of using different weights of Segoe UI:

    1. for light, use font-family: Segoe UI Light
    2. for regular, use just font-family: Segoe UI
    3. for semibold, use use font-family: Segoe UI Semibold
    4. for bold, use font-family: Segoe UI; font-weight: bold

    This is messy and illogical, but it works on Firefox, Chrome, IE, Opera, Safari (tested on Win 7).

    On web pages, it is probably better to try and find a suitable free font with different weights and use it via @font-face. After all, Segoe UI is far from universal, and there is no simple way to set up suitable fallbacks for it.

    0 讨论(0)
  • 2020-12-28 16:57
    @font-face {
        font-family: 'Segoe UI';
        src: url('./ui/segoeui.eot');
        src: local("Segoe UI"),
             local("Segoe"),
             local("Segoe WP"),
             url('./ui/segoeui.eot?#iefix') format('embedded-opentype'),
             url('./ui/segoeui.woff') format('woff'),
             url('./ui/segoeui.svg#SegoeUI') format('svg');
        font-weight: normal;
        font-style: normal;
    }
    
    @font-face {
        font-family: 'Segoe UI Semibold';
        src: url('/semibold/seguisb.eot');
        src: local("Segoe Semibold"),
             local("Segoe WP Semibold"), 
             url('/semibold/seguisb.eot?#iefix') format('embedded-opentype'),
             url('/semibold/seguisb.woff') format('woff'),
             url('/semibold/seguisb.svg#SegoeUISemibold') format('svg');
        font-weight: normal;
        font-style: normal;
    }
    
    @font-face {
        font-family: 'Segoe UI Bold';
        src: url('/bold/segoeuib.eot');
        src: local("Segoe Bold"),
             local("Segoe WP Bold"),
             url('/bold/segoeuib.eot?#iefix') format('eot'), /* Wrong format will tell IE9+ to ignore and use WOFF instead. MSHAR-2822 */
             url('/bold/segoeuib.woff') format('woff'),
             url('/bold/segoeuib.svg#SegoeUIBold') format('svg');
        font-weight: normal;
        font-style: normal;
    }
    
    @font-face {
        font-family: 'Segoe UI Light';
        src: url('/light/segoeuil.eot');
        src: local("Segoe UI Light"),
             local("Segoe WP Light"),
             url('/light/segoeuil.eot?#iefix') format('embedded-opentype'),
             url('/light/segoeuil.woff') format('woff'),
             url('/light/segoeuil.svg#SegoeUILight') format('svg');
        font-weight: normal;
        font-style: normal;
    }
    

    Download:

    https://github.com/KingRider/frontcom/tree/master/css/fonts

    0 讨论(0)
  • 2020-12-28 16:59

    This is from Microsoft's own stylesheet for Windows 8 (Metro) apps:

    /*
    Explicitly define a Segoe UI font-family so that we can assign Segoe UI 
    Semilight to an appropriate font-weight.
    */
    @font-face {
        font-family: "Segoe UI";
        font-weight: 200;
        src: local("Segoe UI Light");
    }
    @font-face {
        font-family: "Segoe UI";
        font-weight: 300;
        src: local("Segoe UI Semilight");
    }
    @font-face {
        font-family: "Segoe UI";
        font-weight: 400;
        src: local("Segoe UI");
    }
    @font-face {
        font-family: "Segoe UI";
        font-weight: 600;
        src: local("Segoe UI Semibold");
    }
    @font-face {
        font-family: "Segoe UI";
        font-weight: 700;
        src: local("Segoe UI Bold");
    }
    @font-face {
        font-family: "Segoe UI";
        font-style: italic;
        font-weight: 400;
        src: local("Segoe UI Italic");
    }
    @font-face {
        font-family: "Segoe UI";
        font-style: italic;
        font-weight: 700;
        src: local("Segoe UI Bold Italic");
    }
    

    The above approach works for me and is also the approach used by Open Sans and Google fonts. However, it is the exact opposite of this approach, originally from Paul Irish:

    @font-face {
        font-family: 'ChunkFiveRegular;
        src: url('whatever source');
        font-weight: normal;
        font-style: normal;
    }
    

    Paul Irish's approach allows (read: requires) setting weights and italics later in the CSS, but the result is "faux": Since the browser doesn't have all the fonts in the family, it has to calculate the weight and shape of the characters on its own to make up for that. The single, and limited strength in Paul's approach is that it might reset the font across all browsers - but it does depend on the font in use - because all browsers render fonts differently!

    I like Microsoft's approach better, because it allows to specify the font-styles and font-weights you need, and the browser will display the correct font file, instead of computing faux sizes, bold and italics. However, it does require you to provide a font file for every font variation in the family you'll be using.

    In the end it all comes down to what font you'll be using and how you use it (different weights, italics, etc). Regardless of what approach you go for, I recommend out of my own experience (and Paul recommends too) to use FontSquirrel's font-face generator for all your web typography endeavors. FontSquirrel can significantly reduce font sizes, by leaving out unnecessary character sets, compressing the fonts, and so on.

    0 讨论(0)
提交回复
热议问题