Фотография на документы. Интерактивный редактор.

02.12.10

Разработка - Работа с интерфейсом

В данном примере описывается внешний отчет 1С:Предприятие 8.1 для загрузки с диска изображения (фотографии), кадрирования фотографии и записи фото с заданными разрешением и форматом на диск. При этом средствами C# и Elisy .Net Bridge создан полноценный редактор, позволяющий интерактивно с наложением анимированной маски менять изображение с одновременным просмотром результата. Обработка и .Net-сборка сделаны максимально гибко, чтобы можно было доработать проект под нужды конкретной реализации, и не привязаны к конкретной конфигурации 1С. Сборка добавляет определенный уровень защиты в проект, так как является результатом компиляции. Исходные коды обработки и C#-проекта открыты и доступны для скачивания.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Обработка Wpf-PhotoEditor.erf
.erf 24,74Kb
59
59 Скачать (1 SM) Купить за 1 850 руб.
Исходный код C# Wpf-PhotoEditor.zip
.zip 105,56Kb
21
21 Скачать (1 SM) Купить за 1 850 руб.

Фотография на документы. Интерактивный редактор.

В данном примере описывается внешний отчет 1С:Предприятие 8.1 для загрузки с диска изображения (фотографии), кадрирования фотографии и записи фото с заданными разрешением и форматом на диск. При этом средствами C# и Elisy .Net Bridge создан полноценный редактор, позволяющий интерактивно с наложением анимированной маски менять изображение с одновременным просмотром результата. Обработка и .Net-сборка сделаны максимально гибко, чтобы можно было доработать проект под нужды конкретной реализации, и не привязаны к конкретной конфигурации 1С. Сборка добавляет определенный уровень защиты в проект, так как является результатом компиляции. Исходные коды обработки и C#-проекта открыты и доступны для скачивания.

Проект состоит из 2х частей: внешнего отчета 1С:Предприятие 8.1 wpf-photoedior.erf и C#-проекта Elisy.PhotoEditor.CroppingTool. Сборка из C#-проекта вложена в виде макета в обработку. Взаимодействие 1С и внешней обработки осуществляется посредством внешнего компонента Elisy .Net Bridge 3.3.

Проект Elisy.PhotoEditor.CroppingTool (C#)

За основу C#-проекта Elisy.PhotoEditor.CroppingTool взяты несколько проектов, размещенных на ресурсе codeproject.com, например, A Photoshop-like Cropping Adorner for WPF. Проект создан средствами Visual Studio 2010 и использует возможности .Net framework 3.5.

PuncturedRect – это класс-геометрическая фигура, состоящая из внешних границ рисунка для редактирования и области редактирования. Определение фигуры происходит в методе DefiningGeometry. В этом классе определены два XAML-свойства: RectInteriorProperty и RectExteriorProperty, отвечающие за внутренний и внешний прямоугольники. Метод CoerceRectInterior не позволяет внутреннему прямоугольнику выходить за границы внешнего прямоугольника.

Основной класс редактора – CroppingAdorner, который наследуется от класса Adorner и тем самым гарантированно является самым верхним графическим элементом. Конструктор принимает 3 объекта: элемент –над которым расположится контрол редактирования, исходное положение/размер прямоугольника для кадрирования и маркер – то что будет нарисовано для пользователя над контролом кадрирования. Конструктор запускает анимацию контуров кадрирования, выставляет начальные позиции для элементов изменения размера и для маркера. Происходит подписка на события изменения размера.

Если пользователь изменит размеры области кадрирования, срабатывает обработчик события HandleThumb, который следит за сохранением пропорции размеров кадрирования, следит, чтобы внутренний прямоугольник не вышел за внешний, запускает событие CropChangedEvent, которое обрабатывается внутри 1С.

Подготовительные операции внешнего отчета 1C wpf-photoedior.erf

Внешний 1С-отчет состоит из формы и макетов: ElisyPhotoEditorCroppingTool – скомпилированная сборка C#-проекта, Xaml- описание интерфейса пользователя в формате XAML/XML, ElisyNetBridgePhotoEditor – исходный код C# 3.5, который компилируется «на лету» внутри 1С, XamlMarker – описание внешнего вида маркера в формате XAML/XML.

Работа внешнего отчета начинается с открытия формы, на которой расположен AcitveX Elisy HwndHost. Именно он отвечает за отображение богатого интерфейса XAML и сообщает о своей готовности событием Created.

После того, как Elisy HwndHost ActiveX готов – вызывается обработчик его события Created – ElisyHwndHostCreated. В обработчике происходят подготовительные операции с элементом ActiveX, чтобы он мог реагировать на изменение размеров формы. Загружается внешний компонент Elisy .Net Bridge, и проверяется, чтобы его версия не была ниже 3.3. Загружается сборка PresentationCore, которая отвечает за работу с XAML. Из макета ElisyNetBridgePhotoEditor извлекается исходный код C# и компилируется вызовом процедуры СкомпилироватьИсходныйКод, на основе его создается объект _photoEditorHelper. Посредством вызова net.LoadAssemblyFromTemplate в память загружается сборка с элементом управления кадрирования. Далее на основе XAML создается визуальный объект через вызов GetWpfControl и вставляется в ActiveX Elisy HwndHost.

Класс Elisy.NetBridge.PhotoEditor.PhotoEditorHelper, скомпилированный из макета ElisyNetBridgePhotoEditor, позволяет 1С-форме обрабатывать .Net-события. Так, например, при изменении области кадрирования вызовется метод формы CropChanged. При закрытии формы необходимо удалить объект в методе формы ПередЗакрытием, чтобы после выхода из 1С программа не зависла в памяти.

За расположение изображений и надписей на форме отвечает XAML-макет Xaml. На основе макета в методе GetWpfControl создается визуальный объект ContentControl, содержащий 2 изображения и надпись "образец" с золотым фоном.

На обработчике события ElisyHwndHostSizeChanged подготовительные операции завершаются. Здесь происходит совмещение размеров XAML-объекта с размерами формы.

Открытие изображения внешним отчетом

Пользователь нажимает на кнопку "Открыть" и вызывается метод формы ДействияФормыКнопкаОткрыть. Появляется диалоговое окно с возможностью выбора файлов типа JPG. В элемент управления _imgOriginal загружается изображение для редактирования. При этом происходит вызов метода SizeChanged 1С-формы, сигнализирующее о том, что фото было добавлено.

В этот момент устанавливается размер элемента кадрирования через вызов метода УстановитьРазмерФотографии. Логика вынесена в отдельную процедуру, чтобы поддерживать различные размеры фотографий.

УстановитьРазмерФоторгафии выставляет прямоугольник кадрирования посредине изображения с заданными в сантиметрах размерами. Плюс к этому на прямоугольник кадрирования накладывает маркер. В примере – это содержимое макета XamlMarker с границами и кругом для получения фотографии на паспорт. В случае необходимости могут быть созданы несколько маркеров-макетов и выбран среди них один. Происходит подписка на событие CropChanged, которое вызывается при изменении размеров прямоугольника кадрирования.

Событие CropChanged вызывает метод RefreshCropImage, который в изображение предпросмотра подставляет необходимую вырезку из исходного изображения.

Запись результирующего изображения

Если пользователь завершил операцию кадрирования и нажал «Записать» срабатывает обработчик события КнопкаСформироватьНажатие.

Появляется диалог выбора файла для записи в формате JPG и происходит запись файла в формате JPG через класс JpegBitmapEncoder.

В случае необходимости изображение может быть записано в формате BMP, GIF, PNG, TIFF, Есть даже необычный фаормат Windows Media Photo (WDP), который, как обещают в Microsoft, дает большее сжатие, чем JPG, при этом более точный. Для этого нужно использовать наследованные от BitmapEncoder-класса классы, входящие в состав .Net framework 3.5.

Заключение

Представленный пример не является простым и раскрывает всю мощь подхода 1C.Net:Предприятие, позволяя гибко обращаться к любым классам, объектам, свойствам и методам .Net framework из 1С. Обратная связь также демонстрируется.

Пример закладывает необходимый фундамент и готов для дальнейшего практического расширения для реализации приложения обработки фотографий на документы. Исходные коды C#-проекта и внешнего 1С-отчета открыты.

Кроме того, пример демонстрирует, каким образом можно защитить конфигурацию, вынеся код в C#-проект и скомпилировав его в .Net-сборку.

Wpf-PhotoEditor.zip (105.56 kb)

Wpf-PhotoEditor.erf (24.74 kb)

См. также

Работа с интерфейсом Рабочее место Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Богатый редактор картинок 1С предназначен для обработки изображений в режиме «Предприятие», с возможностью РИСОВАТЬ на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Обработка будет особенно полезна тем, кто вносит картинки в базу (изображения номенклатуры, фотографии физических лиц и т.п.). Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6000 руб.

16.01.2015    62998    44    59    

82

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 Платные (руб)

Обработка предназначена для создания и управления дашбордами.

2400 руб.

29.06.2020    18869    26    6    

41

Работа с интерфейсом Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Редактор графов в 1С - внешний отчет, который формирует графы на основе таблицы значений, используя рисунки табличного документа. Есть возможность добавления, редактирования объектов графа и выгрузки результата в таблицу значений.

1500 руб.

06.10.2020    10239    7    7    

10

Работа с интерфейсом Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Это инструкция по дизайну форм в среде 1С. Гайд охватывает рекомендации и стандарты для оптимизации пользовательского интерфейса. В гайде содержатся указания по использованию элементов интерфейса, включая как основные, так и продвинутые аспекты. Предоставляются также примеры и антипримеры для наглядного понимания принципов дизайна

20.08.2024    16895    mrXoxot    43    

121

Работа с интерфейсом Программист Платформа 1С v8.3 Бесплатно (free)

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    7432    smielka    37    

100

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    14828    919    elcoan    47    

117

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Подходит для создания web-страниц для замены управляемых форм 1С, красивых отчетов, интерфейса мобильного приложения на платформе 1С и для простых страниц веб-сайтов.

2 стартмани

10.04.2023    11925    162    acces969    31    

124
Внимание! Тема закрыта. Добавлять сообщения в закрытую тему запрещено.
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. пользователь 02.12.10 11:20
Сообщение было скрыто модератором.
...
Оставьте свое сообщение