تغييرات واجهة برمجة التطبيقات العمومية في Aspose.Cells 8.9.1
واجهات برمجة التطبيقات الجديدة
مصادر الخطوط القابلة للتكوين
أصبحت Aspose.Cells for .NET تعرض عددًا من الصفوف لتوفير الدعم لمصادر الخطوط القابلة للتكوين لعرض الجداول الخاصة. وفيما يلي قائمة الصفوف التي تمت إضافتها مع Aspose.Cells for .NET 8.9.1.
- تحديد تهيئات الخطوط الفئة تحدد إعدادات الخطوط.
- فئة FontSourceBase هي فئة قاعدية مجردة للفئات التي تسمح للمستخدم بتحديد مصادر الخطوط المختلفة.
- تمثل فئة FileFontSource ملف الخط TrueType الفردي المخزن في نظام ملفات النظام.
- تمثل فئة FolderFontSource المجلد الذي يحتوي على ملفات خط TrueType.
- تمثل فئة MemoryFontSource ملف الخط TrueType الفردي المخزن في الذاكرة.
- تحدد تعداد عناصر نوع مصدر الخط من خلال تعداد FontSourceType.
بفضل التغييرات المذكورة أعلاه، يسمح Aspose.Cells for .NET بتحديد الخطوط كالتفاصيل أدناه.
- ضبط مجلد خط مخصص واحد أثناء استخدام طريقة FontConfigs.SetFontFolder.
- ضبط عدة مجلدات خط مخصصة أثناء استخدام طريقة FontConfigs.SetFontFolders.
- ضبط مصادر الخط من مجلد خط مخصص، ملف خط واحد أو بيانات خط من مجموعة بايت أثناء استخدام طريقة FontConfigs.SetFontSources.
فيما يلي سيناريو استخدام بسيط للطرق المذكورة أعلاه.
C#
// Defining string variables to store paths to font folders & font file
string fontFolder1 = "D:/Arial";
string fontFolder2 = "D:/Calibri";
string fontFile = "D:/Arial/arial.ttf";
// Setting first font folder with SetFontFolder method
// Second parameter directs the API to search the subfolders for font files
FontConfigs.SetFontFolder(fontFolder1, true);
// Setting both font folders with SetFontFolders method
// Second parameter prohibits the API to search the subfolders for font files
FontConfigs.SetFontFolders(new string[] { fontFolder1, fontFolder2 }, false);
// Defining FolderFontSource
FolderFontSource sourceFolder = new FolderFontSource(fontFolder1, false);
// Defining FileFontSource
FileFontSource sourceFile = new FileFontSource(fontFile);
// Defining MemoryFontSource
MemoryFontSource sourceMemory = new MemoryFontSource(System.IO.File.ReadAllBytes(fontFile));
//Setting font sources
FontConfigs.SetFontSources(new FontSourceBase[] { sourceFolder, sourceFile, sourceMemory});
كما يسمح Aspose.Cells for .NET أيضا بتكوين استبدال الخطوط. هذا الآلية مفيدة عندما لا يتوفر الخط المطلوب على الجهاز الذي سيتم فيه التحويل. يمكن للمستخدمين تقديم قائمة باسماء الخطوط بديلاً عن الخط المطلوب أصلا. ولتحقيق ذلك، قد قدمت واجهات برمجة التطبيقات لـ Aspose.Cells الطريقة FontConfigs.SetFontSubstitutes التي تقبل 2 معامل. الباراميتر الأول من نوع string، والذي يجب أن يكون اسم الخط الذي يجب استبداله. الباراميتر الثاني هو مصفوفة من نوع string. يمكن للمستخدمين تقديم قائمة باسماء الخطوط كاستبدال لاسم الخط الأصلي (المحدد في الباراميتر الأول).
فيما يلي سيناريو استخدام بسيط لطريقة FontConfigs.SetFontSubstitutes.
C#
// Substituting the Arial font with Times New Roman & Calibri
FontConfigs.SetFontSubstitutes("Arial", new string[] { "Times New Roman", "Calibri" });
توفر Aspose.Cells for .NET وسائل أيضاً لجمع المعلومات حول الخطوط والاستبدالات التي تم تعيينها.
- تقوم طريقة FontConfigs.GetFontSources بإرجاع مصفوفة من نوع FontSourceBase التي تحتوي على قائمة مصادر الخطوط المحددة. في حالة عدم تعيين مصادر، ستقوم طريقة FontConfigs.GetFontSources بإرجاع مصفوفة فارغة.
- تقبل طريقة FontConfigs.GetFontSubstitutes معاملا من نوع string الذي يسمح بتحديد اسم الخط الذي تم تعيين استبدال له. في حالة عدم تعيين استبدال لاسم الخط المحدد، ستقوم طريقة FontConfigs.GetFontSubstitutes بإرجاع قيمة null.
تمت إضافة واجهة IFilePathProvider وخاصية HtmlSaveOptions.FilePathProvider
يسمح Aspose.Cells for .NET 8.9.1 بالحصول/التعيين لـIFilePathProvider لتصدير أوراق عمل إلى ملفات HTML منفصلة. هذه واجهات برمجة التطبيقات الجديدة مفيدة في السيناريوهات حيث تشير الروابط الهيبرنق في صفحة عمل واحدة إلى موقع في صفحة عمل أخرى، حيث متطلبات التطبيق هي تقديم كل ورقة عمل إلى ملف HTML منفصل. تنفيذ IFilePathProvider يسمح بالاحتفاظ بالروابط الهيبرنق المذكورة سابقاً بغض النظر عن حقيقة أنها تشير إلى موقع في ملف HTML ناتج منفصل.
فيما يلي سيناريو الاستخدام البسيط لخاصية HtmlSaveOptions.FilePathProvider.
C#
// Load a spreadsheet in an instance of Workbook
var book = new Workbook(dir + "sample.xlsx");
// Save each Worksheet to separate HTML file
for (int i = 0; i < book.Worksheets.Count; i++)
{
book.Worksheets.ActiveSheetIndex = i;
// Create an instance of HtmlSaveOptions & set FilePathProvider property
var options = new HtmlSaveOptions
{
ExportActiveWorksheetOnly = true,
FilePathProvider = new FilePathProvider()
};
// Write HTML file to disc
book.Save(dir + string.Format(@"sheet{0}.html", i), options);
}
إليك كيفية تنفيذ واجهة IFilePathProvider.
C#
public class FilePathProvider : IFilePathProvider
{
public FilePathProvider()
{
}
/// <summary>
/// Gets the full path of the file by Worksheet name when exporting Worksheet to html separately.
/// So the references among the Worksheets can be exported correctly.
/// </summary>
/// <param name="sheetName">Worksheet name</param>
/// <returns>the full path of the file</returns>
public string GetFullName(string sheetName)
{
if ("Sheet2".Equals(sheetName))
{
return "sheet1.html";
}
else if ("Sheet3".Equals(sheetName))
{
return "sheet2.html";
}
return "";
}
}
تمت إضافة خاصية CopyOptions.ReferToDestinationSheet Property وOverload for Cells.CopyRows Method
Aspose.Cells for .NET API قد قامت بتعريض خاصية نوع Boolean CopyOptions.ReferToDestinationSheet بالإضافة إلى إعادة تحميل Cells.CopyRows method من أجل تسهيل عملية نسخ الصفوف عندما تحتوي الصفوف المراد نسخها أيضاً على مخطط ومصدر بياناته. يمكن للمطورين الاستفادة من هذه واجهات برمجة التطبيقات الجديدة لتوجيه مصدر البيانات لمخطط إلى ورقة البيانات الأصلية أو الناتجة.
فيما يلي سيناريو الاستخدام البسيط.
C#
// Load a sample spreadsheet in an instance of Workbook
var book = new Workbook(dir + "sample.xlsx");
// Access the worksheet containing the chart & its data source
var source = book.Worksheets[0];
// Add a new worksheet to the collection
var destination = book.Worksheets[book.Worksheets.Add()];
// Initialize CopyOptions and set its ReferToDestinationSheet property to true
CopyOptions options = new CopyOptions();
options.ReferToDestinationSheet = true;
// Copy the rows
destination.Cells.CopyRows(source.Cells, 0, 0, source.Cells.MaxDisplayRange.RowCount, options);
// Save the result on disc
book.Save(dir + "output.xlsx");
تمت إضافة خاصية CalculationOptions.Recursive.
Aspose.Cells for .NET 8.9.1 قد قامت بتعريض خاصية نوع Boolean CalculationOptions.Recursive. ضبط خاصية CalculationOptions.Recursive إلى true وتمرير الكائن إلى طريقة Workbook.CalculateFormula يوجه واجهات برمجة التطبيقات لـ Aspose.Cells لحساب الخلايا التابعة بشكل متكرر عند حساب الخلايا التي تعتمد على خلايا أخرى.
فيما يلي سيناريو الاستخدام البسيط.
C#
// Load a sample spreadsheet in an instance of Workbook
var book = new Workbook(dir + "sample.xlsx");
// Initialize CalculationOptions & set Recursive property to true
var options = new CalculationOptions();
options.Recursive = true;
// Recalculate formulas
book.CalculateFormula(options);
واجهات برمجة التطبيق القديمة
خاصية CellsHelper.FontDir المهجورة
يُنصح باستخدام الطريقة FontConfigs.SetFontFolder(string, bool) مع تكرار المجلد غير صحيح بدلاً من ذلك.
خاصية CellsHelper.FontDirs المهجورة
استخدام الطريقة FontConfigs.SetFontFolders(string[], bool) مع تكرار المجلد غير صحيح بدلاً من ذلك.
الواجهات المهجورة خاصية CellsHelper.FontFiles
استخدام الطريقة FontConfigs.SetFontSources(FontSourceBase[]) بدلاً من ذلك.