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

Содержание:

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С:Управление холдингом 8

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

ООО «ПраксисКом»
ООО «ПраксисКом»

Отрасль:
Аутсорсинг бухгалтерских услуг

Внедренное типовое решение:
1С:Бухгалтерия ПРОФ

- Бухгалтерский учет:
Банк и касса
Завершение периода
Нематериальные ...

ООО ХДМ Рус
ООО ХДМ Рус

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

Внедренное типовое решение:
1С:Бухгалтерия ПРОФ

Бухгалтерский учет Банк и касса Расчеты с контрагентами Торговые операции ...

ООО «ПЛЮСПЭЙ»
ООО «ПЛЮСПЭЙ»

Отрасль:
Организацией расчетов посредством электронных средств платежа

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

- Разработка подсистемы оперативного учета транзакций...

ПЭК
ПЭК

Отрасль:
Грузоперевозки

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

- Внедрение функционала управления НСИ;
- Рефакторинг;
- Оптимизация общег...

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

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

Внедренное типовое решение:
1С:Бухгалтерия ПРОФ

Документооборот (ECM):
- Учет рабочего времени;
Управление персоналом и ка...

ООО «ПраксисКом»
ООО «ПраксисКом»

Отрасль:
Аутсорсинг бухгалтерских услуг

Внедренное типовое решение:
1С:Управление небольшой фирмой 8 ПРОФ

- Взаиморасчеты с поставщиками
- Учет прихода ТМЦ
- Взаиморасчеты с поку...

Внедрение ПП "1С:Управление небольшой фирмой 8 ПРОФ" в ООО «Шокостайл»
ООО «Шокостайл»

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

Внедренное типовое решение:
1С:Управление небольшой фирмой 8 ПРОФ

Управление продажами, логистикой и транспортом (SFM, WMS, TMS):
- Планирование п...

ООО "СЖД"
ООО "СЖД"

Отрасль:
Торговля, склад, логистика, транспорт

Внедренное типовое решение:
1С:Бухгалтерия 8 ПРОФ

Расчет зарплаты
Подбор кадров
Кадровый учет
Анализ кадрового состава...

АО «РЭП Холдинг»
АО «РЭП Холдинг»

Отрасль:
Энергомашиностроительный холдинг

Внедренное типовое решение:
«1С: Управление производственным предприятием» и «1С:Консолидация ПРОФ»

- Функциональный блок «Консолидированная отчетность РСБУ» - разработка час...

Внедрение ПП "1С:Бухгалтерия 8 ПРОФ" в ООО «Союз Три» (Кондитерский дом Renardi)
ООО «Союз Три»

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

Внедренное типовое решение:
1С:Бухгалтерия 8 ПРОФ

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

Автоматизации учета затрат и расчета себестоимости с использованием конфигурации «Koderline: Управление проектами строительства скважин»
ООО «Буровая сервисная компания «ГРАНД»

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

Внедренное типовое решение:
«Koderline: Управление проектами строительства скважин»

Учет и планирование:
- собственную разработку компании «Кодерлайн» – конф...

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

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

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

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