BusEngine.dll
BusEngine.Browser (Class)
Класс отвечающий за работу с Web файлами (htm, html, css, js, xml и т.д.). Это Web браузер движка.
В основе BusEngine.Browser лежит библиотека CefSharp и Chromium. Найден один минус - не работает видео с кодеком mp4/h.264 т.к. этот кодек защищён патентом и бесплатно нельзя его использовать, в итоге бесплатный браузер Сhromium не поддерживает этот кодек. Решение есть - нужно собрать сборку Chromium с поддержкой этого формата. Но я это изучать и делать не планирую, так как есть альтернатива в виде формата webm, mkv. Чтобы получить качественное видео в формате webm рекомендую конвертёр Format Factory.
Также в Chromium доступны не все API (требуют регистрации и получения бесплатных и(или) платных ключей здесь).
API требующие ключи (список со временем увеличится):
Web Speech API (бесплатное для разработчика и личного использования, и платное);
Методы
var _browser = (BusEngine.Browser)new BusEngine.Browser(null|string, null|string) |
Метод конструктор (нестатический) уровня класса принимает первым параметром string строку веб адреса или полного пути файла, или относительного пути файла от "BusEngine.Engine.DataDirectory" до HTML страницы для запуска браузера и загрузки указанной страницы после вызова "_browser.Load()". Второй параметр string строка корневого пути каталога расположения index.html относительного пути от "BusEngine.Engine.DataDirectory" до index.html или полный путь каталога. |
Метод (нестатический) уровня класса принимает первым параметром string строку веб адреса или полного пути файла, или относительного пути файла от "BusEngine.Engine.DataDirectory" до HTML страницы для запуска браузера и загрузки указанной страницы. Второй параметр string строка корневого пути каталога расположения index.html относительного пути от "BusEngine.Engine.DataDirectory" до index.html или полный путь каталога. |
Метод (нестатический) уровня класса принимает string строку JavaScript кода для его выполнения в текущей вкладки браузера. Это полезно для передачи данных из СSharp кода. |
Метод (нестатический) уровня класса принимает string строку ссылка на скачивание файла. При сохранении файла будет предложено пользователю выбрать куда сохранить файл. |
Метод (нестатический) уровня класса принимает первым параметром string строку ссылка на скачивание файла. Второй параметр string строка указание пути куда сохранить файл (по умолчанию "BusEngine.Engine.LogDirectory + 'Browser/download/'"). При сохранении файла не будет предложено пользователю выбрать куда сохранить файл. |
Метод (нестатический) уровня класса для закрытия "BusEngine.Browser". |
Метод (нестатический) уровня класса для закрытия "BusEngine.Browser" и уничтожения объекта Браузера для освобождения оперативной памяти. Вызывать необязательно так как память освобождается автоматический при событии закрытия Браузера "_browser.Shutdown()". |
Подклассы
(_browser.OnDownloadArgs) _onDownloadArgs = _browser.OnDownloadArgs() |
Подкласс (struct) уровня класса выводит object массив содержащий пути файла, количество и скорость скачивания файла.
(string)_onDownloadArgs.ContentDisposition; // Возвращает расположение содержимого. |
Константы
Поля
Свойства
Свойство (нестатический) уровня класса принимает или возвращает string строку полного пути до папки скачивания файлов. Если указать пустое значение, тогда при скачивании файлов будет открываться окно предлагающее указать путь для сохранения (по умолчанию "BusEngine.Engine.LogDirectory + 'Browser/download/'"). |
События
Событие (нестатический) уровня класса принимает метод с одним параметром (_browser.OnDownloadArgs). Событие "BusEngine.Browser.OnDownload" будет вызывать ваш метод, когда будет загружаться любой файл и передавать в первый параметр подкласс "_browser.OnDownloadArgs()". Событие срабатывает несколько раз по мере скачивания файла. |
Событие (нестатический) уровня класса принимает метод без параметров. Событие "_browser.OnLoad" будет вызывать ваш метод, когда страница будет загружена в "_browser.Load()". |
Событие (нестатический) уровня класса принимает метод с двумя параметрами (object, string). Событие "_browser.OnPostMessage" будет вызывать ваш метод, когда вы вызываете в JavaScript коде функцию "BusEngine.postMessage(string)" при старте своего плагина с названием "MyPlugin" и передавать строку во второй параметр вашего метода, а в первый параметр будет приходить объект "BusEngine.Browser()". |
Пример файла Program.cs
В коде отражён запуск браузера и страницы расположенной относительно папки игровых файлов "BusEngine.Engine.DataDirectory" при старте своего плагина с названием "MyPlugin".
- /** API BusEngine.Game - пользовательский код */
- namespace BusEngine.Game {
- /** API BusEngine.Plugin */
- public class MyPlugin : BusEngine.Plugin {
- // при запуске BusEngine после создания формы Canvas
- public override void InitializeСanvas() {
- BusEngine.Browser.Initialize("index.html");
- BusEngine.Browser.OnPostMessage += (string message) => {
- if (message == "Exit") {
- BusEngine.Engine.Shutdown();
- } else if (message == "Debug") {
- BusEngine.Log.Info("JavaScript: Привет CSharp!");
- BusEngine.Log.Info("На команду: " + message);
- BusEngine.Browser.ExecuteJS("document.dispatchEvent(new CustomEvent('BusEngineMessage', {bubbles: true, detail: {hi: 'CSharp: Прювэт JavaScript!', data: 'Получил твою команду! Вось яна: " + message + "'}}));");
- } else {
- if (message.Substring(0, 8) == "console|") {
- BusEngine.Log.Info(message.Substring(8));
- }
- }
- };
- }
- }
- /** API BusEngine.Plugin */
- }
- /** API BusEngine.Game - пользовательский код */