Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Java [игнор отключен] [закрыт для гостей] / TreeTable - кто каким пользуется? / 25 сообщений из 39, страница 1 из 2
07.11.2006, 16:49:44
    #34109744
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
А где бы скачать компоненту... тьфу. :)

В общем появилась необходимость в TreeTable. Посмотрел реализацию SwingX. Очень похоже на то что описывалось на сайте Sun (уж не знаю что из них первоисточник). Однако необходимость субклассировать DefaultMutableTreeNode под конкретную модель не очень вдохновила.

В связи с этим есть следующие соображения - передавать в конструктор экземпляр наследника от AbstractTableModel, дабы дерево из него ячейки тягало, а для построения дерева субклассировать DefaultTreeTableModel, передать его конструктору строковые параметры KeyField, ParentField, DisplayField, RootValue (то есть имена полей/колонок по которым построится дерево, и корневое значение), и написать внутрё построители чайлдов. Тогда получается универсальный класс модели дерева, который строит представление на базе переданной ему модели таблицы.

Кто-то с подобным игрался?
...
Рейтинг: 0 / 0
07.11.2006, 17:02:21
    #34109792
marx_freedom
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
на сайте Sun есть конечно очень интересная статья (3 части) про TreeTable, только вот в конце написаны "недоделки" - какие именно, точно не помню и посмотреть сейчас не успеваю, но явно чего-то нужного мне не хватало. я остановился на использовании компонента из SwingX, пусть и пришлось унаследоваться от DefaultMutableTreeNode.
--
Солнце встанет непременно!
jabber id: marx [.at.] jabber [.dot.] ru
...
Рейтинг: 0 / 0
07.11.2006, 17:36:26
    #34109949
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
marx_freedomна сайте Sun есть конечно очень интересная статья (3 части) про TreeTable, только вот в конце написаны "недоделки" - какие именно, точно не помню и посмотреть сейчас не успеваю, но явно чего-то нужного мне не хватало. я остановился на использовании компонента из SwingX, пусть и пришлось унаследоваться от DefaultMutableTreeNode.


Наследник DefaultMutableTreeNode там имеет три ключевых метода: getChildren, isLeaf, toString. Замечательно. Передадим в наследника DefaultTreeTableModel экземпляр AbstractTableModel, этот же экземпляр транзитом поедет в конструктор наследника DefaultMutableTreeNode. В нем - вектор хэшей, который представляет собственно датасет (каждый хэш - строка). В DefaultMutableTreeNode добавим экземпляр хэша (грубо говоря ссылки на строку датасета). Тогда в нашем наследнике DefaultMutableTreeNode, получается, есть _всё_ для реализации getChildren, isLeaf, toString, абсолютно независимой от структуры столбцов :)

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

В общем код который с классами работает, получился таким:

FXDTreeModel mdl = new FXDTreeModel(MyDatasetTableModel, stringKeyFieldName,stringParentFieldName,valueRootKey);
this.jXTreeTable1.setTreeTableModel(mdl);

это переменная часть кода которая подхватывает TableModel а вся логика дерева упрятана в класс и работает в зависимости от данных/метаданных датасета.
...
Рейтинг: 0 / 0
07.11.2006, 18:15:42
    #34110098
expp
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
от меня 15 копеек...

вот эта sunовская приверженность к wrapperам всегда меня поражала, да же в StudioCreator'e ObjectProviderы тоже так по извратски сделаны. Ну нафига мне Node'ы в control'ах - мне всегда свои данные показывать надо, и кучу моделей делать в облом
в JFace stateless Provider'ы - ну гораздо красивее

swing в оцтой
...
Рейтинг: 0 / 0
07.11.2006, 18:30:25
    #34110137
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
expp
в JFace stateless Provider'ы - ну гораздо красивее
swing в оцтой

А JFace и SWT могут работать с нетбинсовским дизайнером? Или дизайнеру пофиг, лишь бы BeanInfo был? У меня опыта работы с SWT - ноль. Только скриншоты видел :)
...
Рейтинг: 0 / 0
08.11.2006, 11:16:39
    #34111345
expp
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
канешь не могут. или Swing или JFace. Просто дизайнеров Swingа я нипанимаю....
...
Рейтинг: 0 / 0
08.11.2006, 12:04:25
    #34111597
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
exppканешь не могут. или Swing или JFace. Просто дизайнеров Swingа я нипанимаю....

А в чем JFace интерфейсы конструировать? _Только_ в эклипсе? И где можно внятно почитать - чем таким JFace/SWT лучше чем свинг? C конкретными аргументами?
...
Рейтинг: 0 / 0
08.11.2006, 16:44:30
    #34113161
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
Мне что-то реализация SwingSet не понравилась (уже не помню почему, что-то с ней было не так).

Выбрал L2FProd PropertySheet (пока применение ограничивается реализацией Object и DB Inspector. Разумеется, несколько Display Fields не забабахаешь - а надо ли?).
А их "компонента" собственно и есть реализация AbstractTableModel. Единственная проблема - нулевую колонку сам не отрисуешь да и напильничком бы их табличку обработать :)
...
Рейтинг: 0 / 0
08.11.2006, 17:08:51
    #34113267
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726
Выбрал L2FProd PropertySheet (пока применение ограничивается реализацией Object и DB Inspector. Разумеется, несколько Display Fields не забабахаешь - а надо ли?).
А их "компонента" собственно и есть реализация AbstractTableModel.

Там напильником пилить и пилить...
Вот на картинке собственно то чего мне хотелось. Пока еще в процессе отладки/шлифовки. Зато кормится данными из моего датасета, который тоже которую неделю из-под напильника не вылазит.

Дилемма - для редакторов полей написать интерфейс CellEditorProvider или эвент OnCellEditorComponentNeeded ??? :) Мне это и в гриде нужно - я предусматриваю разные типы редакторов в одной и той же колонке в зависимости от данных в строке датасета...
...
Рейтинг: 0 / 0
08.11.2006, 17:14:01
    #34113292
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726Мне что-то реализация SwingSet не понравилась (уже не помню почему, что-то с ней было не так).


Бугага. Посмотрел я на скриншоты свингсета:

http://swingset.sourceforge.net/Example7.php

Господа прикалываюцца или всерьез? Если эдитор в ячейке подобно Ленину - вечно живой - в этом какой-то сакральный смысл?
...
Рейтинг: 0 / 0
08.11.2006, 20:41:09
    #34113882
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
Скажу по секрету - у меня тоже DataSet уже которую неделю из под напильника не вылазит )) Отсюда и злобность на Java...

Боюсь что ты неправильно вопрос задал (было упомянуто слово DisplayField, без множественного числа) -разумеется, тебе это "творение" не подходит.

C "едиторами" я благо вопрос решил раз и навсегда для любого потомка моей JTable и editor'a - реализатора моего интерфейса (опять же - "равнокриво", но пока устраивает)

А по поводу "бугага" - вот такое же "бугага" есть и в PropertySheet (я уже задолбался при каждом Event'e на DataSet типа "смени Label пожалста" ПОЛНОСТЬЮ перерисовывать их табличку)
...
Рейтинг: 0 / 0
08.11.2006, 21:25:49
    #34113955
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726Скажу по секрету - у меня тоже DataSet уже которую неделю из под напильника не вылазит )) Отсюда и злобность на Java...


"Пилите, Шура, пилите - они золотые!" (с) Паниковский

alexx726
Боюсь что ты неправильно вопрос задал (было упомянуто слово DisplayField, без множественного числа) -разумеется, тебе это "творение" не подходит.


В моём понимании - DisplayField это то что показывается собственно в узлах дерева (в моем скриншоте это код бухсчета). Остальное - это так, колонки приблудные... :)

alexx726
C "едиторами" я благо вопрос решил раз и навсегда для любого потомка моей JTable и editor'a - реализатора моего интерфейса (опять же - "равнокриво", но пока устраивает)


Как, если не секрет? Я вижу два подхода - или передавать конструктору указатель на интерфейс реализующий создание эдиторов, или когда понадобился эдитор бросать эвент и возвращать эдитор из листенера. А у тебя как сделано?
...
Рейтинг: 0 / 0
08.11.2006, 22:09:20
    #34113987
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
"Как, если не секрет? Я вижу два подхода - или передавать конструктору указатель на интерфейс реализующий создание эдиторов, или когда понадобился эдитор бросать эвент и возвращать эдитор из листенера. А у тебя как сделано?"

Ну насчет конечно разных "едиторов" в разных строчках я пожалуй погорячился
(я просто пока не знаю как мне это в рунтайме организовать, в смысле как это прописывать в DataSet :))
...
Рейтинг: 0 / 0
09.11.2006, 09:54:09
    #34114510
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726"Как, если не секрет? Я вижу два подхода - или передавать конструктору указатель на интерфейс реализующий создание эдиторов, или когда понадобился эдитор бросать эвент и возвращать эдитор из листенера. А у тебя как сделано?"

Ну насчет конечно разных "едиторов" в разных строчках я пожалуй погорячился
(я просто пока не знаю как мне это в рунтайме организовать, в смысле как это прописывать в DataSet :))

Мое мнение - из грида наружу должно торчать нечто, которое передает наружу через эвент или через вызов функции имя поля и данные в строке, и получает экземпляр контрола для текущей редактируемой ячейки. Это задача не модели а view/controller-а.
То есть на все столбцы в ColumnModel вешается некий объект, который отрабатывает getCellEditorComponent, из него дергает нечто что отдает ему нужный контрол (ну там же можно и кастомные рендеры присобачить). В результате - грид и модель пишутся один раз и про них забываем, а контролы когда в них возникнет надобность приедут из обработчика событий грида.
...
Рейтинг: 0 / 0
09.11.2006, 11:12:25
    #34114941
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
ну правильно - получишь как раз вариант реализации DevExpress.
Только ломает... :)

Мне, скажем вариант "покажи мне в строчке 1 checkbox, а в строчке 2 ButtonEdit" пригодился до сих пор только один раз - в форме абстрактных аттрибутов чего-либо (а потом все-равно выяснилось, что нужна Custom форма :)). Так что в Java я этого делать не буду.

А если нужен один и тот же компонент - то все разруливается на уровне lookupSQL. Правда, придется запрос обновлять при прорисовке - как это скажется на производительности?
...
Рейтинг: 0 / 0
09.11.2006, 14:55:49
    #34116328
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726
Мне, скажем вариант "покажи мне в строчке 1 checkbox, а в строчке 2 ButtonEdit" пригодился до сих пор только один раз - в форме абстрактных аттрибутов чего-либо (а потом все-равно выяснилось, что нужна Custom форма :)). Так что в Java я этого делать не буду.


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

alexx726
А если нужен один и тот же компонент - то все разруливается на уровне lookupSQL. Правда, придется запрос обновлять при прорисовке - как это скажется на производительности?

Обновлять при прорисовке может не понадобиться - в setCellEditor передаешь объект, внутри которого живет датасет кэширующий данные. Объект соответственно extends AbstractCellEditor implements TableCellRenderer, TableCellEditor, ActionListener, в нем живет контрол создающийся в конструкторе и вылезающий наружу через getTableCellEditorComponent.
...
Рейтинг: 0 / 0
09.11.2006, 15:33:00
    #34116584
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
Vladimir Kozlov
Обновлять при прорисовке может не понадобиться - в setCellEditor передаешь объект, внутри которого живет датасет кэширующий данные. Объект соответственно extends AbstractCellEditor implements TableCellRenderer, TableCellEditor, ActionListener, в нем живет контрол создающийся в конструкторе и вылезающий наружу через getTableCellEditorComponent.

Дык в том то все и дело - а если это разные варианты ComboBox? Ну разные у них DataSet'ы :)) Что, все сразу заполнить? А сколько их?
По mainDataSet пробежаца и выяснить?
Лениво да и формализуется муторно (как я объясню своему dataSetField какой брать - скриптом?)
...
Рейтинг: 0 / 0
09.11.2006, 15:49:44
    #34116688
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726
Дык в том то все и дело - а если это разные варианты ComboBox? Ну разные у них DataSet'ы :)) Что, все сразу заполнить? А сколько их?
По mainDataSet пробежаца и выяснить?
Лениво да и формализуется муторно (как я объясню своему dataSetField какой брать - скриптом?)

Тогда попа. Ну не совсем попа - в основном датасете можно замутить OnCalcFields, чтобы каждый раз при перерисовке по базе не шоркаться а единожды для каждой потребовавшейся записи за значением сбегать и закэшировать, а для эдитора - завести какой-то хэштейбл в котором будет лежать пополняемый при необходимости набор датасетов. Если нужный лукапу датасет в хэштейбле присутствует - берем оттуда, если нет - создаем новый и пихаем в хэштейбл. Ну а "какой брать" - добавь LookupSQL в dataSetField :) (он же и ключом хэша может быть)
...
Рейтинг: 0 / 0
09.11.2006, 16:25:26
    #34116859
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
нее - я ж говорю, муторно...Ленивый я :)
Да и завязано уже все на единый Controller для всего столбца, ну его нафиг.
Уже и так путаца начинаю в своем DataSet - после TableController, InspectorController, FormController + привязки FixedColumns + SummaryFixedRows
и взаимодействия 4-х JTable совсем мозги разъежаются :) А еще бы Groupable Headers ко всему этому безобразию сделать...

Так что от таких "горячих" таблиц я лично откажусь
...
Рейтинг: 0 / 0
09.11.2006, 17:03:54
    #34117003
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726нее - я ж говорю, муторно...Ленивый я :)
Да и завязано уже все на единый Controller для всего столбца, ну его нафиг.
Уже и так путаца начинаю в своем DataSet - после TableController, InspectorController, FormController + привязки FixedColumns + SummaryFixedRows
и взаимодействия 4-х JTable совсем мозги разъежаются :) А еще бы Groupable Headers ко всему этому безобразию сделать...

Так что от таких "горячих" таблиц я лично откажусь

Groupable Headers - я взял сэмпл из инета и переколбасил его чтоб как в EhGrid-е поведение было. Правда на более чем одном уровне группировки не тестил (и работать не будет, не закладывал такой функционал, бо не надо мне).
Кстати поделись идеей как SummaryFixedRows сделал. Решение "в лоб" - увеличить результат getRowCount в модели и отслеживать getValueAt, но суммари будет скроллиться, а чтоб не скроллилось есть подозрение что JScrollPane перекрывать надо...
...
Рейтинг: 0 / 0
09.11.2006, 21:02:07
    #34117566
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
Vladimir Kozlov
Groupable Headers - я взял сэмпл из инета и переколбасил его чтоб как в EhGrid-е поведение было. Правда на более чем одном уровне группировки не тестил (и работать не будет, не закладывал такой функционал, бо не надо мне).
Кстати поделись идеей как SummaryFixedRows сделал. Решение "в лоб" - увеличить результат getRowCount в модели и отслеживать getValueAt, но суммари будет скроллиться, а чтоб не скроллилось есть подозрение что JScrollPane перекрывать надо...

Как сделал? Да по рабоче-крестьянски. Как учат :) Добавляешь новый ScrollPane к панельке с mainScroll, убираешь у него VerticalScrollBar, убираешь у mainScroll HorizontalScrollBar и синхронизуешь HorizontalScrollBar новенького гаденыша с основным. Ежель нужен код - то завтра, на работе. Геморрой разумеется есть с fixedColumns (но это решается, хотя и крышу малость повело от синхронизации). Сами значения Summary храню в Field'е и пересчитываю при всяческих изменениях (поддерживаю пока только COUNT, SUM, AVG, MIN, MAX, CONSTANT - типа текст "Итого:")
...
Рейтинг: 0 / 0
09.11.2006, 21:11:36
    #34117588
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726
Как сделал? Да по рабоче-крестьянски. Как учат :) Добавляешь новый ScrollPane к панельке с mainScroll, убираешь у него VerticalScrollBar, убираешь у mainScroll HorizontalScrollBar и синхронизуешь HorizontalScrollBar новенького гаденыша с основным. Ежель нужен код - то завтра, на работе. Геморрой разумеется есть с fixedColumns (но это решается, хотя и крышу малость повело от синхронизации). Сами значения Summary храню в Field'е и пересчитываю при всяческих изменениях (поддерживаю пока только COUNT, SUM, AVG, MIN, MAX, CONSTANT - типа текст "Итого:")

Ой. и в том скроллпане еще один тейбл?

На случай если у тебя под фикседколумнс тоже отдельный тейбл - похвастаюсь: у меня фиксированные и горизонтально-прокручиваемые колонки в одном тейбле. Автор идеи - какой-то не то индус не то японец, правда в его реализации был полный бардак с убиванием эдитора после редактирования, так что код пришлось перетрясти слегка.
...
Рейтинг: 0 / 0
09.11.2006, 21:42:32
    #34117628
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
вот-вот
Кстати, хороший вопрос для обсуждения - наличие 4-х Tables вместо одной :)
Я пока встретил только плохую и очень плохую реализации. Думаю, что и первоисточник у нас с тобой один :) Только когда я вижу paint() с вызовом getRowcount(), я плачу
...
Рейтинг: 0 / 0
10.11.2006, 09:39:53
    #34118263
Vladimir Kozlov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
alexx726вот-вот
Кстати, хороший вопрос для обсуждения - наличие 4-х Tables вместо одной :)
Я пока встретил только плохую и очень плохую реализации. Думаю, что и первоисточник у нас с тобой один :) Только когда я вижу paint() с вызовом getRowcount(), я плачу

Похоже что да, первоисточник один. Во всяком случае paint() с вызовом getRowcount() там присутствует. Кстати, покажи код editingStopped из твоего варианта - там в первоисточнике один очень сомнительный кусочек кода, интересно глянуть что ты с ним сделал :) А то у меня большое подозрение что там вкопана мина в виде Invalid Cast Exception...
...
Рейтинг: 0 / 0
10.11.2006, 10:01:17
    #34118352
alexx726
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
TreeTable - кто каким пользуется?
дык я ж его не юзал - говорю, заплакал когда увидел перерисовку всех ячеек таблицы (и видимых, и невидимых) после каждого чиха. Не знаю я, как его переделать...
Так что у меня 4 JTable )))
...
Рейтинг: 0 / 0
Форумы / Java [игнор отключен] [закрыт для гостей] / TreeTable - кто каким пользуется? / 25 сообщений из 39, страница 1 из 2
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]