Универсальные формы ввода даты, числа, строки, Виртуальная клавиатура, форма выбора из списка (для сенсорных экранов). Управляемые и обычные формы.

18.03.21

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

Универсальные формы ввода даты, числа, строки, Виртуальная клавиатура, форма выбора из списка. Данные формы используется на сенсорных экранах или когда обычный ввод даты неудобен.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Универсальная форма ввода даты (для сенсорных экранов):
.epf 269,02Kb
9
9 Скачать (2 SM) Купить за 2 150 руб.
Универсальная форма ввода числа (для сенсорных экранов):
.epf 27,18Kb
23
23 Скачать (2 SM) Купить за 2 150 руб.
Виртуальная клавиатура.Универсальная форма ввода строки (для сенсорных экранов):
.epf 29,82Kb
13
13 Скачать (3 SM) Купить за 2 450 руб.
Универсальная форма выбора из списка (для сенсорных экранов):
.epf 213,00Kb
9
9 Скачать (3 SM) Купить за 2 450 руб.
Управляемая Форма. Универсальная форма ввода числа (для сенсорных экранов):
.epf 9,85Kb
22
22 Скачать (2 SM) Купить за 2 150 руб.
Управляемая Форма. Универсальная форма ввода даты (для сенсорных экранов):
.epf 25,06Kb
9
9 Скачать (2 SM) Купить за 2 150 руб.

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

Работает на любой конфигурации, формы и обычные и управляемые, мы тестировали на УПП 1.3 (обычные) и на ERP 2.5 (управляемые).

Как пользоваться: вы хотите выбирать значение через эту форму, подменяете процедуру выбора этого значения на процедуру общего модуля (пример ниже), при необходимости передаете туда значение для редактирования (если это не ввод нового значения), после работы с формой нужно обработать результат - вам вернется выбранное значение, если пользователь отказался, то вернется "Неопределено".


///////////// УПРАВЛЯЕМЫЕ ФОРМЫ /////////////
 
// Ввод числа
&НаКлиенте
Процедура ВесБруттоНачалоВыбора
	ОписаниеЗакрытия = Новый ОписаниеОповещения("ОповещениеВводВесБрутто",ЭтаФорма);
	МК_КалькуляторыКлиент.КалкВвестиЧисло(ЭтаФорма, ОписаниеЗакрытия, НашеЧисло);
КонецПроцедуры

// Вводит число через обработку для сенсорного экрана
//
// Параметры:
//  ФормаВладелец  		- Форма - Форма источник
//  ОповещениеЗакрытия  	- ОписаниеОповещения - Описание оповещения при закрытии формы
//  НачальноеЗначение  		- Число - Исходное число для редактирования
//
Процедура КалкВвестиЧисло(ФормаВладелец, ОповещениеЗакрытия, НачальноеЗначение = 0, Заголовок = "") Экспорт
	
	ОткрытьФорму("ОбщаяФорма.МК_ВводЧисла", 
	Новый Структура("НачальноеЗначениеВводаЧисла, Заголовок", НачальноеЗначение, Заголовок),
	ФормаВладелец,
	,
	ВариантОткрытияОкна.ОтдельноеОкно,
	,
	ОповещениеЗакрытия,
	РежимОткрытияОкнаФормы.БлокироватьВесьИнтерфейс);	
	
КонецПроцедуры // КалкВвестиЧисло()

// Ввод даты
&НаКлиенте
Процедура ВыбратьДату(Команда)	
	ОписаниеЗакрытия = Новый ОписаниеОповещения("ОповещениеВыбораДаты",ЭтаФорма);
	МК_КалькуляторыКлиент.КалкВвестиДату(ЭтаФорма, ОписаниеЗакрытия, Объект.ДатаВыработки);	
КонецПроцедуры

// Вводит дату через обработку для сенсорного экрана
//
// Параметры:
//  ФормаВладелец  		- Форма - Форма источник
//  ОповещениеЗакрытия  	- ОписаниеОповещения - Описание оповещения при закрытии формы
//  НачальноеЗначение  		- Дата - Исходная дата для редактирования
//
Процедура КалкВвестиДату(ФормаВладелец, ОповещениеЗакрытия, НачальноеЗначение = 0) Экспорт
	
	ОткрытьФорму("ОбщаяФорма.МК_ВводДаты", 
	Новый Структура("ДатаОтсчета", НачальноеЗначение),
	ФормаВладелец,
	,
	ВариантОткрытияОкна.ОтдельноеОкно,
	,
	ОповещениеЗакрытия,
	РежимОткрытияОкнаФормы.БлокироватьВесьИнтерфейс);	
	
КонецПроцедуры // КалкВвестиЧисло()


///////////// ОБЫЧНЫЕ ФОРМЫ ///////////// 

// Ввод строки
Процедура Пример

СтрокаДляРедактирования = "Тест";

СтрокаДляРедактирования = НастройкиФорм.ВводСтроки(СтрокаДляРедактирования);

КонецПроцедуры


// Открывает форму интерактивного ввода строки
//
// Параметры:
//  Строка - Строка
//              строка для редактирования
Функция ВводСтроки(Строка = Неопределено) Экспорт
        
    Если Строка = Неопределено Тогда
        Строка = "";
    КонецЕсли;
    
    ФормаСтрока = ПолучитьФорму("ОбщаяФорма.МК_ФормаВводаСтроки");
    ФормаСтрока.Строка = Строка;
    Строка = ФормаСтрока.ОткрытьМодально();
    
        Возврат Строка;
    
КонецФункции

// Ввод числа
Процедура Пример

ЧислоДляРедактирования = 124;

ЧислоДляРедактирования = НастройкиФорм.ВводЧисла(ЧислоДляРедактирования );

КонецПроцедуры


// Открывает форму интерактивного ввода числа
//
// Параметры:
//  Число - Число
//             число для редактирования
Функция ВводЧисла(Число = Неопределено) Экспорт

    Если Число = Неопределено Тогда
        Число = 0;
    КонецЕсли;
    
    ФормаЧисла = ПолучитьФорму("ОбщаяФорма.МК_ФормаВводаЧисла");
    ФормаЧисла.Число = Число;
    Число = ФормаЧисла.ОткрытьМодально();
    
    Возврат Число;
    
КонецФункции


// Ввод даты
Процедура Пример

ДатаДляРедактирования = ТекущаяДатаСеанса();

ДатаДляРедактирования = НастройкиФорм.ВводДаты(ДатаДляРедактирования);

КонецПроцедуры

// Открывает форму интерактивного ввода даты
//
// Параметры:
//  Дата - Дата
//             дата для редактирования
Функция ВводДаты(Дата = Неопределено) Экспорт
        
    Если Дата = Неопределено ИЛИ НЕ ЗначениеЗаполнено(Дата) Тогда
        Дата = ТекущаяДатаСеанса();
    КонецЕсли;
    
    ФормаДаты = ПолучитьФорму("ОбщаяФорма.ФормаВводаДаты");
    ФормаДаты.ТекущаяДата = Дата;
    Дата = ФормаДаты.ОткрытьМодально();
    
    Возврат Дата;
        
КонецФункции

// Выбор из списка
Процедура Пример

СписокВозврата = Новый СписокЗначений;

Запрос = Новый Запрос;
Запрос.Текст =
        "ВЫБРАТЬ
        |    Склады.Ссылка КАК Ссылка,
        |    Склады.Наименование КАК Наименование
        |ИЗ
        |    Справочник.Склады КАК Склады
        |ГДЕ
        |    НЕ Склады.ПометкаУдаления
        |
        |УПОРЯДОЧИТЬ ПО
        |    Наименование";
   
РезультатЗапроса = Запрос.Выполнить();   
ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();
    
Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
    СписокСкладов.Добавить(ВыборкаДетальныеЗаписи.Ссылка, СокрЛП(ВыборкаДетальныеЗаписи.Наименование));
КонецЦикла;

ПеремещениеТекущийСклад = НастройкиФорм.ВыбратьИзСписка(СписокСкладов, 2);

КонецПроцедуры

// Открывает форму интерактивного выбора из списка
//
// Параметры:
//  СписокВыбора - СписокЗначений - Список из которого нужно выбрать
//  РежимРаботы - Число - Вариант отображения: 1 - в один столбец, 2 - в два столбца
//
Функция ВыбратьИзСписка(СписокВыбора, РежимРаботы) Экспорт
        
    ФормаВыбораИзСписка = ПолучитьФорму("ОбщаяФорма.ФормаВыбораИзСписка");
    ФормаВыбораИзСписка.СписокВыбора     = СписокВыбора;
    ФормаВыбораИзСписка.РежимРаботы     = РежимРаботы;
    ВыбранноеЗначение = ФормаВыбораИзСписка.ОткрытьМодально();
    
    Возврат ВыбранноеЗначение;
    
КонецФункции

 

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

См. также

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

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

6000 руб.

16.01.2015    63495    44    59    

82

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

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

2400 руб.

29.06.2020    19359    27    6    

42

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

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

1500 руб.

06.10.2020    10630    7    7    

11

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

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

20.08.2024    19677    mrXoxot    44    

126

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

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

27.05.2024    9365    smielka    37    

103

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

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

27.12.2023    17385    1210    elcoan    52    

123

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

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

2 стартмани

10.04.2023    12335    166    acces969    31    

124
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. yarsort 141 21.11.18 15:22 Сейчас в теме
В окне выбора значения надо заголовок подправить: "Выберите значение".
2. Izumov 14 21.05.19 09:03 Сейчас в теме
(1)
В окне выбора значения надо заголовок подправить: "Выберите значение".

С грамматикой проблема, извиняюсь :)
3. vlad636 10 17.03.21 10:44 Сейчас в теме
Приветствую. Проблемы с вводом числа. Попробуйте ввести например 0,708. Второй ноль не вводится, т.к. там явное преобразование строки в число, соответственно 0,70 преобразуется в 0,7, как обойти?
4. Izumov 14 18.03.21 10:45 Сейчас в теме
(3) Исправил. Обработку обновил.

Или сами поправьте у себя:
Процедура "ЦифраНажатие(Элемент)"
Меняем Число = Число(Строка(Число) + Строка(Добавить));
на Число = Строка(Число) + Строка(Добавить);
5. vlad636 10 18.03.21 10:52 Сейчас в теме
6. vlad636 10 15.04.21 11:15 Сейчас в теме
Приветствую еще раз. Теперь проблемы с выбором из списка.
Ошибка при вызове метода контекста (ЗаполнитьЗначенияСвойств)
		ЗаполнитьЗначенияСвойств(НоваяКнопка, ШаблоннаяКнопка, , "Данные, ИсточникДействий, Видимость");
по причине:
Ошибка установки значения свойства 'Имя'
по причине:
Не уникальное имя!
7. Izumov 14 19.05.21 16:38 Сейчас в теме
(6) Вы одинаковые значения передали в выбор? Они должны быть уникальны, там кнопки создаются.
8. vlad636 10 20.05.21 03:14 Сейчас в теме
(7) Решил вопрос, даже не помню уже что там было
9. vlad636 10 06.05.22 07:58 Сейчас в теме
Приветствую, а есть Универсальная форма выбора из списка (для сенсорных экранов) для управляемых форм?
10. Izumov 14 09.05.22 22:25 Сейчас в теме
11. Zebar 69 05.01.23 15:38 Сейчас в теме
А как вводить отрицательные числа?
Оставьте свое сообщение