Как итог вид отчета
Натолкнулся на проблему, в нете все решения сделаны базово. Мне необходимо было сделать так что бы была возможность выводить несколько изображений и они не были привязаны к определенным колонкам.
Фактически необходимо показать изображение которое стоит основным в справочнике номенклатуры, а также все изображения из справочника "ПрисоединенныеФайлы". В этой обработке возможно будет ошибка, так как я не проверяю, это картинка или нет, необходимо доделывать проверку.
В итоге запрос из схемы компоновки данных:
ВЫБРАТЬПлюсом к моей задаче необходимо было оценить сколько файлов прикреплено.
НоменклатураПрисоединенныеФайлы.Ссылка КАК Файл,
НоменклатураПрисоединенныеФайлы.ВидФайла,
НоменклатураПрисоединенныеФайлы.ФайлХранилище,
НоменклатураПрисоединенныеФайлы.ВладелецФайла,
ПрисоединенныеФайлы.ХранимыйФайл КАК Картинка,
СпрНоменклатура.Ссылка КАК Номенклатура,
ПрисоединенныеФайлы.ХранимыйФайл КАК КоличествоФайлов,
СпрНоменклатура.Ссылка КАК КоличествоНоменклатуры,
НоменклатураПрисоединенныеФайлы.ВладелецФайла КАК КоличествоНоменклатурыСФайлами,
СпрНоменклатура.ФайлКартинки
ИЗ
Справочник.Номенклатура КАК СпрНоменклатура
ЛЕВОЕ СОЕДИНЕНИЕ Справочник.НоменклатураПрисоединенныеФайлы КАК НоменклатураПрисоединенныеФайлы
ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.ПрисоединенныеФайлы КАК ПрисоединенныеФайлы
ПО НоменклатураПрисоединенныеФайлы.Ссылка = ПрисоединенныеФайлы.ПрисоединенныйФайл
ПО СпрНоменклатура.Ссылка = НоменклатураПрисоединенныеФайлы.ВладелецФайла
Добавляем параметр ширину колонки, для красоты вывода
И оформляем настройки
Выводим только заполненные дополнительные строки
И код модуля
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) СтандартнаяОбработка = Ложь; ДокументРезультат.Очистить(); НастройкиОтчета = КомпоновщикНастроек.ПолучитьНастройки(); КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных; Макет = КомпоновщикМакета.Выполнить(СхемаКомпоновкиДанных, НастройкиОтчета, ДанныеРасшифровки); ПроцессорКомпоновки = Новый ПроцессорКомпоновкиДанных; ПроцессорКомпоновки.Инициализировать(Макет, , ДанныеРасшифровки); ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВТабличныйДокумент; ПроцессорВывода.УстановитьДокумент(ДокументРезультат); ИмяКолонкиИзображения = "Файл"; ШиринаКолонкиИзображения = ВернутьЗначениеПараметраНастройкиСКД(КомпоновщикНастроек.Настройки.ПараметрыДанных.Элементы, "ШиринаКолонкиИзображения", 20); ПроцессорВывода.НачатьВывод(); Пока Истина Цикл ЭлементРезультата = ПроцессорКомпоновки.Следующий(); Если ЭлементРезультата = Неопределено Тогда Прервать; КонецЕсли; ПроцессорВывода.ВывестиЭлемент(ЭлементРезультата); Если ЭлементРезультата.ЗначенияПараметров.Количество() = 0 Тогда Продолжить; КонецЕсли; Для Каждого ЭлементПараметра Из ЭлементРезультата.ЗначенияПараметров Цикл Если ТипЗнч(ЭлементПараметра.Значение) = Тип("ИдентификаторРасшифровкиКомпоновкиДанных") Тогда Поля = ДанныеРасшифровки.Элементы[ЭлементПараметра.Значение].ПолучитьПоля(); Для Каждого Поле Из Поля Цикл Если ТипЗнч(Поле.Значение) = Тип("СправочникСсылка.НоменклатураПрисоединенныеФайлы") Тогда Если Поле.Значение.Пустая() Тогда Продолжить; КонецЕсли; //Поиск номера колонки, с нужным именем ИмяКолонкиИзображения, для таки вывода изображения Для НомерКолонки = 1 По ДокументРезультат.ШиринаТаблицы Цикл Расшифровка = ДокументРезультат.Область(ДокументРезультат.ВысотаТаблицы, НомерКолонки, ДокументРезультат.ВысотаТаблицы, НомерКолонки).Расшифровка; Если Расшифровка = Неопределено Тогда Продолжить; КонецЕсли; Поля = ДанныеРасшифровки.Элементы.Получить(Расшифровка).ПолучитьПоля(); Для Каждого знчПоле Из Поля Цикл Если знчПоле.Значение = Поле.Значение тогда ОбластьИзображения = ДокументРезультат.Область(ДокументРезультат.ВысотаТаблицы, НомерКолонки); ВывестиИзображениеЭлементаНоменклатуры(ДокументРезультат, Поле.Значение, ОбластьИзображения, ШиринаКолонкиИзображения); КонецЕсли; КонецЦикла; КонецЦикла; КонецЕсли; КонецЦикла; КонецЕсли; КонецЦикла; КонецЦикла; ПроцессорВывода.ЗакончитьВывод(); КонецПроцедуры Процедура ВывестиИзображениеЭлементаНоменклатуры(ТД, ЭлементСправочника, Область, ШиринаКолонкиИзображения) Если ЭлементСправочника.ТипХраненияФайла = Перечисления.ТипыХраненияФайлов.ВИнформационнойБазе Тогда СтуктураРег = РегистрыСведений.ПрисоединенныеФайлы.Получить(Новый Структура("ПрисоединенныйФайл,ВидФайла", ЭлементСправочника,ЭлементСправочника.ВидФайла)); ДанныеКартинки = СтуктураРег.ХранимыйФайл.Получить(); Иначе ДанныеКартинки = ?(ЗначениеЗаполнено(ЭлементСправочника.Том.ПолныйПутьWindows), ЭлементСправочника.Том.ПолныйПутьWindows, ЭлементСправочника.Том.ПолныйПутьLinux) + ЭлементСправочника.ПутьКФайлу; КонецЕсли; Рисунок = ВывестиИзображениеВОбластиТД(ДанныеКартинки, ТД, Область); Область.АвтоВысотаСтроки = Ложь; Область.ВысотаСтроки = ШиринаКолонкиИзображения * 1.31 / 0.3759;// Среднее значение пункта 1 пункт = 0.3759 мм (по Wiki) Область.Расшифровка = ЭлементСправочника; Рисунок.ЦветЛинии = Область.ЦветРамки; КонецПроцедуры Функция ВывестиИзображениеВОбластиТД(ДанныеКартинки, ТД, Область) Изображение = ТД.Рисунки.Добавить(ТипРисункаТабличногоДокумента.Картинка); Изображение.РазмерКартинки = РазмерКартинки.АвтоРазмер; Индекс = ТД.Рисунки.Индекс(Изображение); ТД.Рисунки[Индекс].Картинка = Новый Картинка(ДанныеКартинки, Истина); ТД.Рисунки[Индекс].Расположить(Область); Возврат ТД.Рисунки[Индекс]; КонецФункции Функция ВернутьЗначениеПараметраНастройкиСКД(КоллекцияЭлементовНастройки, ИмяНастройки, ЗначениеПоУмолчанию = Неопределено) Настройка = КомпоновщикНастроек.Настройки.ПараметрыДанных.Элементы.Найти(ИмяНастройки); Если Настройка = Неопределено Тогда Возврат ЗначениеПоУмолчанию; КонецЕсли; НастрокаПоИД = КомпоновщикНастроек.ПользовательскиеНастройки.Элементы.Найти(Настройка.ИдентификаторПользовательскойНастройки); Если Не ЗначениеЗаполнено(НастрокаПоИД.Значение) Тогда Если Не ЗначениеПоУмолчанию = Неопределено Тогда НастрокаПоИД.Значение = ЗначениеПоУмолчанию; КонецЕсли; КонецЕсли; Возврат ?(НастрокаПоИД.Использование, НастрокаПоИД.Значение, ЗначениеПоУмолчанию); КонецФункции
No comments:
Post a Comment