Відтворення математичних формул LaTeX | .NET
Як відобразити математичну формулу LaTeX у форматі PNG
Довідковий розділ API, пов’язаний із цією темою, знаходиться тут. Насправді, найпростіший спосіб продемонструвати функцію відтворення математичних формул LaTeX — це почати з прикладу. Ось воно:
1// Create rendering options setting the image resolution to 150 dpi.
2PngMathRendererOptions options = new PngMathRendererOptions();
3options.Resolution = 150;
4// Specify the preamble.
5options.Preamble = @"\usepackage{amsmath}
6\usepackage{amsfonts}
7\usepackage{amssymb}
8\usepackage{color}";
9// Specify the scaling factor 300%.
10options.Scale = 3000;
11// Specify the foreground color.
12options.TextColor = System.Drawing.Color.Black;
13// Specify the background color.
14options.BackgroundColor = System.Drawing.Color.White;
15// Specify the output stream for the log file.
16options.LogStream = new System.IO.MemoryStream();
17// Specify whether to show the terminal output on the console or not.
18options.ShowTerminal = true;
19
20// Create the output stream for the formula image.
21using (System.IO.Stream stream = System.IO.File.Open(
22 System.IO.Path.Combine(RunExamples.OutputDirectory, "math-formula.png"), System.IO.FileMode.Create))
23{
24 // Run rendering.
25 System.Drawing.SizeF size = new PngMathRenderer().Render(@"\begin{equation*}
26e^x = x^{\color{red}0} + x^{\color{red}1} + \frac{x^{\color{red}2}}{2} + \frac{x^{\color{red}3}}{6} + \cdots = \sum_{n\geq 0} \frac{x^{\color{red}n}}{n!}
27\end{equation*}", stream, options);
28
29 // Show other results.
30 System.Console.Out.WriteLine(options.ErrorReport);
31 System.Console.Out.WriteLine();
32 System.Console.Out.WriteLine("Size: " + size); // Dimensions of the resulting image.
33}
Перейдемо до деталей. Перш за все, ми створюємо екземпляр параметри візуалізації, подібний до набору TeX/LaTeX. Ми робимо це тут, одночасно вказуючи роздільну здатність вихідного зображення.
Далі уточнюємо преамбулу. Типова преамбула:
1\usepackage{amsmath}
2\usepackage{amsfonts}
3\usepackage{amssymb}
який забезпечує трохи розширенішу підтримку математичних формул, ніж базовий LaTeX. Ви можете, наприклад, додати пакет color
, якщо хочете використовувати власне виділення у формулі, як ми показали у прикладі коду.
Потім ми наказуємо рендереру масштабувати вихід на 300%.
Наступні два параметри визначають кольори переднього плану та фону. Ті частини формули, які не охоплені («забарвлені») спеціальним виділенням, відображатимуться кольором «Колір тексту».
Наступний рядок прикладу не має особливого сенсу. Це просто демонструє, що ви можете спрямувати вихід журналу в якийсь потік.
І остання опція ShowTerminal
дозволяє вам перемикати запис виводу терміналу на консоль.
Метод, який фактично виконує візуалізацію, це MathRenderer.Render(). Він повертає розмір формули в пунктах.
Потік, у який буде записано зображення, приймається методом як другий аргумент. Далі створюємо потік.
І, нарешті, ми викликаємо сам метод MathRenderer.Render()
, передаючи параметри як третій аргумент. Код LaTeX формули передається як перший аргумент.
Останні рядки прикладу друкують два артефакти відтворення математичної формули - розмір формули та короткий звіт про помилку (якщо помилки є).
Ось результат візуалізації.
Це найзагальніший варіант використання функції відтворення математичних формул LaTeX.
Ви також можете переглянути безкоштовну веб-програму, створену на основі функції, реалізованої в Aspose.TeX для .NET API.
Як відобразити математичну формулу LaTeX у SVG
Приблизно так само ми можемо відобразити математичну формулу LaTeX у форматі SVG.
1// Create rendering options.
2MathRendererOptions options = new SvgMathRendererOptions();
3// Specify the preamble.
4options.Preamble = @"\usepackage{amsmath}
5\usepackage{amsfonts}
6\usepackage{amssymb}
7\usepackage{color}";
8// Specify the scaling factor 300%.
9options.Scale = 3000;
10// Specify the foreground color.
11options.TextColor = System.Drawing.Color.Black;
12// Specify the background color.
13options.BackgroundColor = System.Drawing.Color.White;
14// Specify the output stream for the log file.
15options.LogStream = new System.IO.MemoryStream();
16// Specify whether to show the terminal output on the console or not.
17options.ShowTerminal = true;
18
19// Create the output stream for the formula image.
20using (System.IO.Stream stream = System.IO.File.Open(
21 System.IO.Path.Combine(RunExamples.OutputDirectory, "math-formula.svg"), System.IO.FileMode.Create))
22{
23 // Run rendering.
24 System.Drawing.SizeF size = new SvgMathRenderer().Render(@"\begin{equation*}
25e^x = x^{\color{red}0} + x^{\color{red}1} + \frac{x^{\color{red}2}}{2} + \frac{x^{\color{red}3}}{6} + \cdots = \sum_{n\geq 0} \frac{x^{\color{red}n}}{n!}
26\end{equation*}", stream, options);
27
28 // Show other results.
29 System.Console.Out.WriteLine(options.ErrorReport);
30 System.Console.Out.WriteLine();
31 System.Console.Out.WriteLine("Size: " + size); // Dimensions of the resulting image.
32}
Відмінності:
- Ми використовуємо клас SvgMathRendererOptions замість PngMathRendererOptions.
- Ми не вказуємо роздільну здатність.
- Ми використовуємо клас SvgMathRenderer замість PngMathRenderer.
Ось результат:
Ви також можете переглянути безкоштовну веб-програму, створену на основі функції, реалізованої в Aspose.TeX для .NET API.