В моем домене есть объекты, которые постоянно обновляются отдельным процессом, и я хочу, чтобы PropertySheetView отображал изменяющиеся свойства. Текущая реализация настроена таким образом, что базовый объект модели предметной области является неизменным, и, таким образом, при его изменении публикуется новый объект с соответствующим идентификатором. В этот момент мой узел, обертывающий объект, подписался, получает обновленный объект с соответствующим идентификатором, воссоздает лист (через createSheet()) и вызывает setSheet с обновленной информацией. Это прекрасно работает, всегда показывая самую последнюю версию объекта модели предметной области.
Однако некоторые свойства доступны не только для чтения, но и для установки. Я хотел бы заблокировать лист от обновления/перезаписи либо по строке, либо по листу, пока свойство редактируется. Чтобы сделать это, мне нужно прослушивать вызовы начала и конца редактирования, чтобы я мог знать, когда безопасно снова обновить лист.
Это очень важно для моего приложения; в настоящее время вы не можете ввести новое значение до тех пор, пока лист не будет обновлен, и ваше редактирование не исчезнет.
Если это имеет значение, я использую пользовательский PropertyEditorSupport, но InplaceEditor по умолчанию.
Я провел много поисков в исходном коде NetBeans и не нашел каких-либо открытых настроек API для прослушивания этого материала.
SheetCellEditor (org.openide.explorer.propertysheet) предоставляет метод addCellEditorListener, но A) я не могу понять, как мне получить дескриптор экземпляра SheetCellEditor, и B) методы, предоставляемые SheetCellEditor, editCanceled и editStopped - нет обратного вызова для начала редактирования! Кажется очень глупым. SheetTable и BaseTable также будут раскрывать это свойство, поскольку они расширяют JTable, но я также не могу понять, как получить к ним доступ.
Я заметил, что интерфейс CellEditor требуется метод isCellEditable(), который предположительно возвращает true, если ячейку можно редактировать, и, таким образом, начинается редактирование. Но опять же, это реализовано в SheetCellEditor, который не является общедоступным классом, и я не знаю, как получить на него ссылку.
Спасибо за помощь.