Построение графиков с несколькими показателями на форме

22.08.19

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

Один из вариантов программного построения графиков на форме обработки.

Коллеги, доброго времени суток. 

На днях поступила задача отображения данных на диаграмме в форме обработки, а точнее создание онлайн-табло с графиками. При построении диаграммы с помощью СКД проблем не возникло. Поиски в Google и на форумах не увенчались успехом. Для того чтобы данную задачу решить на форме обработки было сделано следующее

На форме обработки создано поле диаграммы

В модуле формы написан следующий код

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

	РезультатЗапроса = Запрос.Выполнить();
	
	Диаграмма.Обновление = Ложь;
	Диаграмма.Очистить();
	Диаграмма.АвтоТранспонирование = Ложь;

	  Серия = Диаграмма.Серии.Добавить();
	  Серия2 = Диаграмма.Серии.Добавить();
	  Серия3 = Диаграмма.Серии.Добавить();
	  Серия4 = Диаграмма.Серии.Добавить();
	  Серия5 = Диаграмма.Серии.Добавить();


	  //Точка2 = Диаграмма.Точки.Добавить();
	ВыборкаДатаПериода = РезультатЗапроса.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам);
	
	Пока ВыборкаДатаПериода.Следующий() Цикл
		 // Серия = Диаграмма.Серии.Добавить();
		Точка = Диаграмма.УстановитьТочку(Формат(ВыборкаДатаПериода.ДатаПериода,	"ДФ=dd.MM.yyyy"));

		Диаграмма.УстановитьЗначение(Точка, Серия, ВыборкаДатаПериода.ФактНарастающий, );
		Диаграмма.УстановитьЗначение(Точка, Серия2, ВыборкаДатаПериода.План75, );
		Диаграмма.УстановитьЗначение(Точка, Серия3, ВыборкаДатаПериода.ПрогнозНарастающий, );
		Диаграмма.УстановитьЗначение(Точка, Серия4, ВыборкаДатаПериода.ФактПоступлений, );
		Диаграмма.УстановитьЗначение(Точка, Серия5, ВыборкаДатаПериода.ПланНарастающий, );
		//Диаграмма.УстановитьЗначение(Точка, Серия6, ВыборкаДатаПериода.ПрогнозНарастающий, );
	КонецЦикла;
	
	Диаграмма.АвтоТранспонирование = Истина;
	Диаграмма.Обновление = Истина;
	Диаграмма.ОтображатьЛегенду=Ложь;
	

 ЭлементыФормы.Надпись84.Заголовок ="Выполнение плана продаж за " + Формат(ДатаСреза, "ДФ=ММММ")+" месяц по состоянию на "+Формат(ТекущаяДата(),	"ДФ=dd.MM.yyyy") + " процент выполнения " + выполнениеПлана;
	

В параметрах была передана таблица значений.  В итоге был получен желаемый результат.

Эта публикация является примером ее можно перестроить под свои задачи.

В связи с тем что сам давно искал решение данной задачи. Нашел и решил написать публикацию. 

Буду рад услышать отзывы так и критику в свой адрес. Прошу сильно не бить, если что-то не так написал.  

Спасибо за внимание.

Вступайте в нашу телеграмм-группу Инфостарт

диаграммы обработка построение графиков

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

28800 руб.

27.03.2025    56405    31    25    

45

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36000 руб.

28.08.2025    2703    1    2    

4

Работа с интерфейсом Системный администратор Программист 1С:Предприятие 8 1C:Бухгалтерия Платные (руб)

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

6000 руб.

14.01.2016    58242    20    25    

46

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

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

5160 руб.

29.06.2020    22865    32    6    

51

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

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

5040 руб.

06.10.2020    12852    8    8    

14

Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

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

20.08.2024    43395    mrXoxot    44    

138

Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

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

27.05.2024    24834    smielka    38    

111
Для отправки сообщения требуется регистрация/авторизация