TrueType Yazı Tiplerini Belirt

Bu konu, Aspose.Words’in TrueType yazı tiplerini ararken varsayılan davranışını açıklar, işletim sistemi spesifik farklılıkları içerir ve kullanıcı yazı tipi kaynaklarını nasıl belirteceğinizi gösterir.

The FontSourceBase sınıfı çeşitli yazı kaynaklarını belirtmek için kullanılır. Sınıfın birden fazla uygulaması var: FontSourceBase

Bazı sınıflar için uygulama detayları aşağıda açıklanmıştır.

Sistemden Yazı Tiplerini Yükle

Varsayılan olarak her zaman kullanılan özel bir SystemFontSource sınıfı var. Bu sistemde yüklü tüm TrueType yazı tiplerini temsil eder. Bu nedenle, SystemFontSource ve diğer gereken kaynaklarla bir kaynak listesi oluşturmak mümkündür:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java
FontSettings.getDefaultInstance().setFontsSources(
new FontSourceBase[] { new SystemFontSource(), new FolderFontSource("C:\\MyFonts\\", true) });
Document doc = new Document(dataDir + "Rendering.doc");
dataDir = dataDir + "Rendering.SetFontsFolders_out.pdf";
doc.save(dataDir);

A single instance of the SystemFontSource class varsayılan olarak FontSettings ‘de tanımlanır. Farklı işletim sistemlerinde yazı tipleri farklı yerlerde olabilir. Ancak her belge için bir FontSettings örneği kullanmak en ideal çözüm değildir. Çoğunlukla durumlarda DefaultInstance kullanmak yeterli olmalı.

Per-belge örnekleri yalnızca farklı belgeler için farklı yazı tipleri kullanmak istendiğinde gereklidir ki bu da nadiren bir durumdur. Birçok FontSettings örneği performansın azalmasına neden olur çünkü bunları önbellek paylaşmazlar.

Where Aspose.Words Looks for TrueType Fonts on Windows

Çoğu durumda, Windows kullanıcıları eksik yazı tipleri veya hatalı düzenler ile önemli sorunlarla karşılaşmazlar. Tipik olarak Aspose.Words bir belgeyi tarar ve yazı tipine ait bağlantı ile karşılaştığında yazı tipi verilerini sistem klasöründen başarıyla alır.

On Windows, Aspose.Words tüm kullanılabilir yazı tiplerini %windir%\Fonts klasöründen ilk alır. Bu ayar sizin çoğu zaman için işe yarayacaktır. Sadece ihtiyacın olduğunda kendi yazı tipleri klasörlerini belirtirsin. Aspose.Words ayrıca, HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts kayıt anahtarında kayıtlı ekstra yazı tiplerini de arar. Ayrıca Windows 10 geçerli kullanıcı için yazı tiplerinin yüklenmesini sağlar. Fontlar %userprofile%\AppData\Local\Microsoft\Windows\Fonts klasörüne yerleştirilir ve ayrıca HKEY_CURRENT_USER\Software\Microsoft\Windows NT\CurrentVersion\Fonts kayıt defterinde belirtilir, burada Aspose.Words bu yazı tiplerini arar.

Bir belge gömülü yazı tipleri içeriyorsa, Aspose.Words ilgili yazı tipi verilerini belgeden okuyabilir ve bunları belgenin düzenini oluşturmak için kullanabilir. Belgelere ayrıca sistem klasörlerinde olmayan yazı tiplerine bağlantılar da içerebilir ve bu durumda aşağıdaki senaryolar geçerlidir:

  • Kullanıcıların yazı tipleri için yeni kaynak kurmaları FontSettings sınıfı aracılığıyla mümkün olabilir
  • Aspose.Words bir benzer yazı tipini eksik olanla değiştirmeye çalışabilir

Non-Windows Sistemlerdeki Yazı Tipleri

Aspose.Words sistem yazı tipleri klasörlerinde yazı tiplerini arayacaktır. Bu klasörlerin bir listesi GetSystemFontFolders yöntemi ile görülebilir. Desteklenen yazı tipleri bulunamazsa, Aspose.Words yerleşik varsayılan yazı tipi Fanwood.ttf’yi kullanacaktır.

Tasarım ölçümleri Windows ve non-Windows OS farklı olduğundan, Aspose.Words bir benzer yazı tipini bulmak ve orijinaline benzer bir düzen oluşturmak için mümkün olan her şeyi yapar. Ancak bu her zaman mümkün değildir. Bu durumlarda, FontSettings sınıfı özel yazı tiplerini veya değiştirme kurallarını eklemek için kullanılmalıdır.

Where Aspose.Words Looks for TrueType Fonts on Linux

Farklı Linux dağıtımlar yazı tiplerini farklı klasörlerde saklayabilir. Aspose.Words birkaç yerde yazı tipleri arar. Varsayılan olarak Aspose.Words, tüm aşağıdaki konumlarda yazı tiplerini arar: /usr/share/fonts /usr/local/share/fonts /usr/X11R6/lib/X11/fontsBu varsayılan davranış çoğu Linux dağıtımı için çalışacaktır, ancak bu durumda true tipi yazı tiplerinin konumunu açıkça belirtmeniz gerekir. Bunu yapmak için, Linux dağıtımda TrueType yazı tiplerinin nerede kurulduğunu bilmeniz gerekir.

Mac OS X’de Where Aspose.Words Looks for TrueType Fonts

Aspose.Words Mac OS X’te TrueType yazı tiplerinin standart konumu olan /Library/Fonts klasöründe yazı tipleri arar. Bu ayar sizin için çoğu zaman işe yarayacak olsa da, ihtiyacınız olduğunda kendi yazı tipiniz klasörlerinizi belirtmeniz gerekebilir.

TrueType Yazı Tipleri Android üzerinde

On Android tipografi iş akışı Typeface sınıfında kapsüllendi. Tipografilerde beş çeşit vardır ve her tipografi türü benzer yazı ailelerinin bir grubunu temsil eder:

  • DEFAULT
  • DEFAULT_BOLD -MONOSPACE
  • SANS_SERIF
  • SERİF

Örneğin, Android’in fonts.xml yapılandırma dosyasına göre, “times” “serif” ailesine ait olduğundan NotoSerif-Regular.ttf, “times” istendiğinde kullanılacaktır:

Fontlar.xml

<family name="serif">
        <font weight="400" style="normal">NotoSerif-Regular.ttf</font>
        <font weight="700" style="normal">NotoSerif-Bold.ttf</font>
        <font weight="400" style="italic">NotoSerif-Italic.ttf</font>
        <font weight="700" style="italic">NotoSerif-BoldItalic.ttf</font>
</family>
<alias name="times" to="serif" />
<alias name="times new roman" to="serif" />

Benzer yazı tiplerini aramak için daha önce tarif edilen stratejiler kullanılır

Onların yanı sıra, Aspose.Words platformu için Android’in kendi değiştirme listesi vardır.

Belgenin PMingLiU-ExtB yazı tipini içerdiğini söyleyelim. Öncelikle, Aspose.Words gerekli yazı tipini sistem kaynaklarında arıyor.

Varsayılan liste Android yazı tipleri klasörlerinin:

  • /system/fonts
  • /system/font
  • /data/fonlar

The Aspose.Words kullanıcı tarafından tanımlanan kaynaklardan geçer ve aşağıdaki yöntem kullanılarak ayarlanır:

Java

fontSettings.setFontsFolder("/home/user/MyFonts", true);

Açık bir değiştirme belirtilmişse, Aspose.Words eksik yazı tipini kullanıcının önerisiyle değiştirir:

Java

fontSettings.getSubstitutionSettings().getTableSubstitution().setSubstitutes("PMingLiU-ExtB", "Liberation Serif");

Eğer kurallardan hiçbirisi işe yaramadı," Aspose.Words" iç eki değiştirme tablosunu kontrol et. Tablo iyi bir uyum hakkında bilgi içeriyorsa yazı tipi değiştirilir. Bizim durumumuzda Aspose.Words Typeface.SERIF‘i seçer Ama tablo istediği yazı tipini bilmiyorsa Aspose.Words özel bir MS Word kuralına veya Panose uzayındaki en yakın mesafeye dayalı bir yazı tipi seçer.

TrueType Yazılar .NET Core ve Xamarin üzerinde

.NET Core ve Xamarin için, Aspose.Words’ın Java sürümü için aynı kural geçerlidir. Varsayılan olarak, uygulamayı çalıştıran platformun tüm sistem yazı tipleri mevcuttur. Aramanın gerçekleştirileceği klasörlerin listesi, metod çağrılmasıyla bulunabilir:

Java

SystemFontSource().getAvailableFonts()

Klasörden yazı tiplerini yükle

İşlemdeki belge sistemde olmayan yazı tiplerine bağlantılar içeriyorsa veya bunları sistem klasörüne eklemek istemiyorsanız veya izinlere sahip değilseniz, en iyi çözüm kendi yazı tiplerinizi içeren bir klasör eklemek ve bunu SetFontsSources yöntemini kullanmak. Bu, sistem kaynağını bir kullanıcı kaynağıyla değiştirecek. Aspose.Words artık kayıt defterinde veya Windows\Font klasöründe yazı tiplerini aramayacak ve bunun yerine belirtilen klasörlerdeki (ler) yazı tiplerini taramayacaktır. GetFontSources yöntemi, karşılık gelen değerleri döndürecektir.

Bir veya Birden Çok Yazı Klasörünü Belirtin

The SetFontsFolder ve SetFontsFolders yöntemleri bir veya birkaç FolderFontSource örneklerini içeren SetFontSources yöntemi için kısayollar. Bu yöntemler, Aspose.Words’ün yazı tiplerini nerede araması gerektiğini göstermek için kullanılır. Bir klasör mevcut değilse veya erişilemiyorsa Aspose.Words bu klasörü sadece görmezden gelir. Kaynaklar dahil olmak üzere tüm klasörler yoksayılırsa, Aspose.Words varsayılan olarak Fanwood yazı tipini kullanacaktır.

Aşağıdaki örnek bir klasör veya kaynağın ayarlanmasını gösterir hangi Aspose.Words daha sonra yazı tiplerini görselleştirme veya gömme sırasında aramak için kullanılacaktır:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java
// For complete examples and data files, please go to
// https://github.com/aspose-words/Aspose.Words-for-Java
Document doc = new Document(dataDir + "Rendering.doc");
FontSettings FontSettings = new FontSettings();
// Note that this setting will override any default font sources that are being
// searched by default. Now only these folders will be searched for
// Fonts when rendering or embedding fonts. To add an extra font source while
// keeping system font sources then use both FontSettings.GetFontSources and
// FontSettings.SetFontSources instead.
FontSettings.setFontsFolder("C:\\MyFonts\\", false);
// Set font settings
doc.setFontSettings(FontSettings);
doc.save(dataDir + "Rendering.SetFontsFolder_out.pdf");

Ek bir Boole parametresi, yazı tiplerinin tüm klasörlerde yinelemeli olarak taranıp taranmayacağını kontrol eder, bu nedenle belirtilen bir klasörün tüm alt klasörlerini tarar. Aşağıdaki örnek, render ederken veya yazı tiplerini gömerek birden fazla klasörde aramak için Aspose.Words’i nasıl ayarlayacağınızı göstermektedir:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java
// For complete examples and data files, please go to
// https://github.com/aspose-words/Aspose.Words-for-.NET
// Open a Document
Document doc = new Document(dataDir + "Rendering.doc");
FontSettings FontSettings = new FontSettings();
// Note that this setting will override any default font sources that are being
// searched by default. Now only these folders will be searched for
// Fonts when rendering or embedding fonts. To add an extra font source while
// keeping system font sources then use both FontSettings.GetFontSources and
// FontSettings.SetFontSources instead.
FontSettings.setFontsFolders(new String[] { "C:\\MyFonts\\", "D:\\Misc\\Fonts\\" }, true);
// Set font settings
doc.setFontSettings(FontSettings);
doc.save(dataDir + "Rendering.SetFontsFolders_out.pdf");

Bu örneğin şablon dosyasını Aspose.Words GitHub‘tan indirebilirsiniz.

Sistem yazı tiplerini tamamen kullanmak istemiyorsanız, Aspose.Words onları görmezden gelmenizi ve sadece kendi yazı tiplerinizi kullanmanızı sağlar:

Java

FontSettings.getDefaultInstance().setFontsFolder("C:\\MyFonts\\", true);

Öncelikli Mülk

Priority özelliği farklı yazı kaynaklarında aynı aile adı ve stilde yazı tipleri olduğunda kullanılır. Bu durumda Aspose.Words öncelikli değere sahip kaynaklardan yazı tipini seçer. Örneğin sistem klasöründe yazı tipinin eski bir sürümü var ve müşteri aynı yazı tipinin yeni bir sürümünü özel bir klasöre ekledi.

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java
FontSettings.getDefaultInstance().setFontsSources(
new FontSourceBase[] { new SystemFontSource(), new FolderFontSource("C:\\MyFonts\\", true, 1) });

Akıştan yazı tipleri yükle

Aspose.Words sağlar StreamFontSource sınıfı, akıştan yazı tiplerini yüklemeyi sağlayan. Akış yazı tipi kaynağını kullanmak için bir kullanıcı, StreamFontSource sınıfından türetilen bir sınıf oluşturmalı ve OpenFontDataStream yöntemine bir uygulama sağlamalıdır. The OpenFontDataStream yöntem birkaç kez çağrılabilir. İlk defa, Aspose.Words kullanılabilir yazı tiplerinin bir listesini elde etmek için sağlanan yazı tipi kaynaklarını tarar ve çağrılır. Daha sonra, dosya biçiminde kullanılıyorsa yazı tipinin verilerini ayrıştırmak ve bazı çıktı formatlarına gömmek için çağrılabilir. StreamFontSource faydalı olabilir çünkü yalnızca gerekli olduğunda yazı tipi verilerini yüklemesine izin verir ve bunu bellekte FontSettings yaşam süresi boyunca saklamaz.

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java
public void streamFontSourceFileRendering() throws Exception {
FontSettings fontSettings = new FontSettings();
fontSettings.setFontsSources(new FontSourceBase[]{new StreamFontSourceFile()});
DocumentBuilder builder = new DocumentBuilder();
builder.getDocument().setFontSettings(fontSettings);
builder.getFont().setName("Kreon-Regular");
builder.writeln("Test aspose text when saving to PDF.");
builder.getDocument().save(dataDir + "FontSettings.StreamFontSourceFileRendering.pdf");
}
/// <summary>
/// Load the font data only when required instead of storing it in the memory for the entire lifetime of the "FontSettings" object.
/// </summary>
private static class StreamFontSourceFile extends StreamFontSource {
public FileInputStream openFontDataStream() throws Exception {
return new FileInputStream(dataDir + "Kreon-Regular.ttf");
}
}

StreamFontSource MemoryFontSource‘ye bir alternatiftir çünkü her zaman bellekte bir akış yüklemek ve bunu MemoryFontSource‘e geçirmek mümkündür. Fark şu ki, MemoryFontSource tüm zaman hafızada tutulur ve StreamFontSource talep üzerine yüklenir ve derhal ortadan kaldırılır. Ancak yukarıda açıklandığı gibi birkaç kez yüklenebilir. Bazı durumlarda MemoryFontSource tercih edilir ve diğerlerinde StreamFontSource‘dir.

Bir Yazı Arama Önbelleğini Kaydet ve Yükle

Bir yazı tipi ararken ilk kez, Aspose.Words kullanıcı tarafından belirtilen yazı tipi kaynaklarını yineleyecek ve bu kaynaklardan gelen verilere dayalı olarak bir yazı tipi arama önbelleği oluşturacaktır. Böylece, önbellek mevcut yazı tipleri hakkında bilgi biriktirir: yazı tipi ailesi, stil, tam yazı tipi adı ve diğerleri. Sonraki çağrılarda, Aspose.Words, arzu edilen yazı tipi adını kullanarak yazı tipinin önbelleğinde arama yapar, sonrasında belirtilen dosyaları ayrıştırarak yazı tipini kullanır.

Tüm mevcut yazı tiplerini ayrıştırmak için kullanılan prosedür oldukça zaman alıcıdır. Aspose.Words FontSettings.SaveSearchCache yöntemini kullanarak önbelleği kaydetmenize ve yüklemenize olanak tanır, böylece performans sorunu çözülür. Yani kullanıcı bir dosyadan önceden kaydedilmiş önbelleği yükleyebilir ve tüm mevcut yazı tiplerini ayrıştırma adımını atlayabilir.

Kullanılabilir Yazı Tipleri Listesi Al

Eğer mevcut yazı tiplerinin listesini almak istiyorsanız, örneğin bir PDF belgesi oluşturmak için kullanılabilecekleri yazı tipleri, aşağıdaki kod örneğinde gösterildiği gibi GetAvailableFonts yöntemini kullanabilirsiniz. The PhysicalFontInfo sınıfı Aspose.Words yazı motoru için mevcut olan fiziksel yazı tipi hakkındaki bilgileri belirtir:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java
// Get available system fonts
for (PhysicalFontInfo fontInfo : (Iterable<PhysicalFontInfo>) new SystemFontSource().getAvailableFonts()) {
System.out.println("FontFamilyName : " + fontInfo.getFontFamilyName());
System.out.println("FullFontName : " + fontInfo.getFullFontName());
System.out.println("Version : " + fontInfo.getVersion());
System.out.println("FilePath : " + fontInfo.getFilePath());
}
// Get available fonts in folder
for (PhysicalFontInfo fontInfo : (Iterable<PhysicalFontInfo>) new FolderFontSource(dataDir, true)
.getAvailableFonts()) {
System.out.println("FontFamilyName : " + fontInfo.getFontFamilyName());
System.out.println("FullFontName : " + fontInfo.getFullFontName());
System.out.println("Version : " + fontInfo.getVersion());
System.out.println("FilePath : " + fontInfo.getFilePath());
}
// Get available fonts from FontSettings
ArrayList<FolderFontSource> fontSources = new ArrayList(
Arrays.asList(FontSettings.getDefaultInstance().getFontsSources()));
// Convert the Arraylist of source back into a primitive array of FontSource
// objects.
FontSourceBase[] updatedFontSources = (FontSourceBase[]) fontSources
.toArray(new FontSourceBase[fontSources.size()]);
for (PhysicalFontInfo fontInfo : (Iterable<PhysicalFontInfo>) updatedFontSources[0].getAvailableFonts()) {
System.out.println("FontFamilyName : " + fontInfo.getFontFamilyName());
System.out.println("FullFontName : " + fontInfo.getFullFontName());
System.out.println("Version : " + fontInfo.getVersion());
System.out.println("FilePath : " + fontInfo.getFilePath());
}