31.10.2019 Анна Белокопытова 17409
Перетаскивание данных между элементами форм -...

Содержание:

1. Интерфейс Drag-n-Drop

2. События, возникающие у элементов форм управляемых форм 1С при перетаскивании данных

3. Реализация обработки перетаскивания данных  

    

1.    Интерфейс Drag-n-Drop


Во многих современных системах применяется технология перетаскивания элементов интерфейса Drag-n-Drop. Она позволяет увеличить скорость и удобство работы пользователя.


В прикладных решениях на платформе «1С:Предприятие» 8 так же есть возможность реализовать перетаскивание данных между элементами форм. В данной статье мы познакомимся с основными принципами организации перетаскивания элементов на форме, событиями, возникающими у элементов форм при перетаскивании, а также рассмотрим пример реализации задачи перетаскивания данных.


Возможность перетаскивания можно реализовать для элементов: поле табличного документа,табличное поле,поле картинки, поле календаря.


Тот элемент, из которого будут перетаскиваться данные пользователем, является источником перетаскивания. А тот элемент, в который будут помещены данные – приемником перетаскивания.

Для того, чтобы элемент управления мог выступать в роли источника или приемника данных необходимо установить значения следующих свойств:


·         РазрешитьНачалоПеретаскивания. Если флаг у этого свойства установлен, то у пользователя будет возможность перетащить данные из этого элемента формы.

·         РазрешитьПеретаскивание. Если флаг установлен, то пользователь сможет перетащить данные в этот элемент управления



Рисунок 1 – Свойства «РазрешитьНачалоПеретаскивания» и «РазрешитьПеретаскивание»  


2.    События, возникающие у элементов форм управляемых форм 1С при перетаскивании данных:


В тот момент, когда пользователь нажимает мышкой на элементе управления, выступающим в качестве источника, возникает событие «Начало перетаскивания».


Параметры, передаваемые в обработчик:


·         Параметры перетаскивания - тип «ПараметрыПеретаскивания». Этот параметр передается во все обработчики событий 1С перетаскивания и имеет свойства:


-   «Действие» - тип «ДействиеПеретаскивания», может принимать значения «Выбор», «Копирование», «Перемещение»,«Отмена»,

-  «Допустимые действия» - тип «ДопустимыеДействияПеретаскивания». Определяет, какие действия будут выполняться над перетаскиваемыми данными: Hе обрабатывать, Перемещение,Копирование, Копирование и перемещение (файлов).

-  «Значение» - тип определяется типом элемента управления, являющегося источником данных. Содержит перетаскиваемые данные. Кроме того, значение этого свойство можно менять.


·         Выполнение – тип «Булево», устанавливая значение этого параметра в Ложь или Истина можно определять будет ли выполняться стандартная обработка. Т.е если значение этого параметра в теле обработчика изменить на«Ложь», то событие перетаскивание не начнется.


Затем, когда курсор мыши наводится на элемент управления, являющийся приёмником данных, у него возникает событие «Проверка перетаскивания». В параметрах обработчика, кроме параметров «Параметры перетаскивания» и «Стандартная обработка», могут так же содержаться и другие параметры, в зависимости от вида элемента управления. Например, для 1С 8 Табличного документа в параметрах будет содержаться еще и Область, для Поля календаря – ВыбраннаяДата, для Таблицы - Строка и Поле. 


В обработчике этого события можно запретить перетаскивание в 1С текущий элемент управления, или разрешить только копирование, при этом внешний вид курсора будет меняться(зависит от того, какое значение принимает свойство Действие).


После, когда пользователь опускает клавишу мыши на выбранном им элементе управления возникает событие «Перетаскивание».


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


Самым последним возникает событие «ОкончаниеПеретаскивания» у элемента источника данных. В обработчике события 1С можно описать какие действия нужно выполнить в элементе – источнике данных, например, удалить перемещенную строку из табличного поля.  


3.    Реализация обработки перетаскивания данных


Рассмотрим пример реализации перетаскивания данных, источники данных и приемники данных.

Необходимо реализовать перетаскивание товаров из одной таблицы в другую, при этом количество товаров в первой таблице должно уменьшаться, а во второй увеличиваться.


На форму обработки добавим две таблицы СписокТоваров и СписокПокупок с колонками

1С Номенклатура и Количество:



Рисунок 2 – Таблица-источник и Таблица-приемник на форме обработки


Для таблицы СписокТоваров установим, которая будет являться источником данных установим в истину свойство РазрешитьНачалоПеретаскивания



Рисунок 3 – Свойство «Разрешить начало перетаскивания» элемента-источника данных

 

Для таблицы СписокПокупок установим, которая будет являться приемником данных установим в истину свойство РазрешитьПеретаскивание



Рисунок 4 – Свойство «Разрешить перетаскивание» элемента-приемника данных

 

В обработчике события «Перетаскивание» у таблицы «СписокПокупок», являющейся приемником, свойство Значение параметра «ПараметрыПеретаскивания» имеет тип Массив и содержит перетаскиваемые данные. В нашем случае – это строки таблицы значений 1С 8.3. Если пользователь выделит несколько строк и будет их перетаскивать, то в массиве будут содержаться все выделенные строки. Поэтому обработку необходимых действий с данными реализуем в цикле.




Проверяем, есть ли в таблице товар, который перетаскивает пользователь. Если есть, то увеличиваем количество на единицу. Если нет, то добавляем новую строку в таблицу с количеством, равным 1.


В обработчике события «ОкончаниеПеретаскивания» у таблицы «СписокПокупок», являющейся приемником, так же в цикле для всех перетаскиваемых строк уменьшаем количество на единицу:




Теперь попробуем проверить обработку в пользовательском режиме 1С.

В таблице-источнике добавлены три строки с товарами и количеством 10:



Рисунок 5 – Таблицы до перетаскивания


Выделим две строки и попробуем перетащить их в таблицу-приемник:



Рисунок 6 – Таблицы после перетаскивания

 

После перетаскивания в таблице приемнике появилось две строки с товарами и количеством, равным 1. А в таблице источнике количество для этих товаров уменьшилось на единицу. Этот результат и требовалось получить по условиям задачи.


Специалист компании ООО «Кодерлайн»
Анна Белокопытова

Наши проекты

ООО «Еврорадиаторы»
ООО «Еврорадиаторы»

Отрасль:
1С:ERP 2.4

Внедренное типовое решение:

Специалисты «Кодерлайн» помогли перенести базу из текущей системы «1С:ERP 2.2» в новую систему «1С:ERP 2.4». ...

Фармацевтическое предприятие «Оболенское»
АО «Фармацевтическое предприятие «Оболенское»

Отрасль:
Фармацевтическая промышленность

Внедренное типовое решение:
1С:Управление производственным предприятием

- Адаптации блоков/подсистем планирования продаж, закупок и казначейства. ...

Внедрение «1С:Зарплата и управление персоналом 8 КОРП» в компании «ПБК»
ООО «Партнер Бухгалтер Консультант»

Отрасль:
Бухгалтерские услуги

Внедренное типовое решение:
1С:Зарплата и управление персоналом

- Интеграция продукта с базой данных оперативного учета Axapta;
- Доработка функционала подсистемы...

Автоматизации бизнес-процессов учета и планирования на базе «1С:ERP Управление предприятием 2.0»
ООО «Буровая сервисная компания «ГРАНД»

Отрасль:
Нефтесервис

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

- Создание полноценной управленческой системы взамен существующих
- Внедрением подсистем «Нормативное планирования», «Мобильное АРМ», «Ре...

ООО «Стейдж Энтертейнмент Россия»
ООО «Стейдж Энтертейнмент Россия»

Отрасль:
Театральная деятельность

Внедренное типовое решение:
Платформа 1С:Предприятие 8

Реализован процесс трансформации данных бухгалтерского учета по РСБУ в данные международного учета (ГААП) на платформе «1С:Предприятие 8»:...

ФГУП «Почта России»
ФГУП «Почта России»

Отрасль:
Почта, доставка

Внедренное типовое решение:
1С:Зарплата и управление персоналом

- Бухгалтерский учет
- Расчет зарплаты и кадровый учет
- Налоговый учет ...

Установка программного продукта БИТ.Финанс для 1С:Бухгалтерия 8
ООО «Джи Эй Си Шиппинг энд Лоджистикс»

Отрасль:
Транспорт

Внедренное типовое решение:
БИТ.Финанс

Построение единого информационного пространства финансовой службы;
Учет бухгалтерский, налоговый, бюджетный, включая регламентированную ...

ООО "ОМЗ"
ООО "ОМЗ"

Отрасль:
Металлургическая промышленность, металлообработка

Внедренное типовое решение:
1С:Управление производственным предприятием

Автоматизация бизнес-процессов...

Внедрение системы финансового учета БИТ:Финанс
ООО «Алькор и Ко» (Л’Этуаль)

Отрасль:
Торговля

Внедренное типовое решение:
БИТ.Финанс

- Финансовый учет;
- Поддержка проекта внедрения МСФО;
- Регламентные работы по обслуживанию сервера MS SQL;
- Оптимизация производ...

ООО «ПКП КАБЭЛЕКТРОСНАБ»
ООО «ПКП КАБЭЛЕКТРОСНАБ»

Отрасль:
Производство кабельной продукции

Внедренное типовое решение:
1С:Управление небольшой фирмой 1.6

- Оформление заказов покупателей;
- Управление складскими запасами;
- Анализ запасов/остатков...

Автоматизация документооборота в компании ООО "Ликард"
ООО «Ликард» (ОАО ЛУКОЙЛ)

Отрасль:
Нефтесервис

Внедренное типовое решение:
1С:Документооборот КОРП

- Отказ от бумажного документооборота, от громоздких систем на базе офисного пакета;
- Создан единообразный интерфейс как в офисе, так и...

Внедрение блока расчета себестоимости РАУЗ в 1С:УПП 8
ООО «Пелигрин Матен»

Отрасль:
Производство

Внедренное типовое решение:
1С:Управление производственным предприятием

– Оформление заказов покупателей;
– Взаиморасчеты с покупателями;
– Оформление заказов поставщикам;
– Управление отношениями с ...

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение