-
MY PROJECTS
-
Recent Posts
- Reading.CleanArchitecture.Thoughts
- Algo.Java.PascalTriangle.ExampleOfDynamicProgramming
- Algo.Java.Find2Mins.InO(n)
- Algo.Java.RecursiveSlidingWindow
- Java.Algo.SlidingWindow
- Algo.Java.SlidingWindow.DoublingArrayForCircle
- Algo.Java.BinarySearch.For.Peaks
- Algo.Java.BinarySearch.Tip
- Algo.Java.BitManipulation.AnotherExample
- Algo.Java.SetBitMask
- Algo.Java.DFS.In.Matrix.AnotherExample2
- Algo.Java.DFS.In.Matrix.Another.Example
- Algo.Java.DFS.In.Matrix
- Algo.Java.BFS.In.Matrix
- Java.Algo.Kadane.MaxSumOfSubArray
- Algo.Java.GetBitFromInteger
- Algo.Java.BinarySearch.BrilliantProblem
- Algo.Java.StringTips
- Algo.Java.LoopSpeed
- Algo.Java.Arrays.AnotherExampleOfFrequencyApproach
Categories
- Aptana
- Azure
- C#
- DataSnap
- DBExpress
- Delphi
- Delphi и сети
- Delphi. Язык программирования
- ExtJS
- FastReport
- FireDAC
- FireMonkey
- GIT
- ICS
- IDE
- IIS
- Indy
- InnoSetup
- javascript
- jQuery
- JSON
- LiveBindings
- MSHTML
- MySQL
- PHP
- REST
- Ribbons
- SMS
- SQL инструкции
- SVN
- TRichView
- UniGui
- WebBroker
- WinAPI
- Windows
- Алгоритмы
- Без рубрики
- Деревья
- Ищу ответ
- Компонентостроение
- Мои компоненты
- Начальный уровень
- Обработка исключений
- Парсинг
- Потоки(Threads)
- Регулярные выражения
- Тестирование приложений
Category Archives: Деревья
DbTreeView. Разработка компонента. Результат. Вторая волна
Данная статья – результат разработки компонента DBTreeView. Для одного из проектов понадобился такой компонент, а в готовом виде, с необходимым функционалом для моей задачи его не оказалось. Компонент настроен на базу MySQL. В принципе его можно переписать на любую другую … Continue reading
Posted in Delphi, Без рубрики, Деревья
Comments Off on DbTreeView. Разработка компонента. Результат. Вторая волна
Delphi. Иерархические данные. DBTreeView своими руками. Поиск в дереве при наборе текста
Дополним DBTreeView поиском при наборе текста,
Posted in Delphi, Без рубрики, Деревья
Comments Off on Delphi. Иерархические данные. DBTreeView своими руками. Поиск в дереве при наборе текста
Delphi. Иерархические данные. DBTreeView своими руками. Вырезать и вставить
В данной статье код вырезки узлов, выделенных галочками и вставка в Selected узел. Все происходит из отдельного потока, так как процесс может затянуться. Работа состоит из 2-х частей – обновление в базе и обновление в самом дереве. После копирования и … Continue reading
Delphi. Иерархические данные. DBTreeView своими руками. Добавление изображений из ресурсов
На протяжении всего проекта мы наблюдали иконки папок и чекбоксы, подгруженные в виде картинок с диска. Сейчас же я хочу загружать их из ресурсов. Если, например, делать свой компонент из цикла статей про DBTreeView, то без загрузки картинок из ресурсов … Continue reading
Delphi. TTreeView. Корректная замена StateIndex иконок при DragDrop
Корректно заработало только при таком коде – сначала пришлось поставить другую иконку, потом вернуть её на место.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
procedure TDMDB.UpdateStateIndex(Node: TTreeNode); var i:integer; begin if Node.StateIndex=2 then begin Node.StateIndex:=1; Node.StateIndex:=2; end else begin Node.StateIndex:=2; Node.StateIndex:=1; end; // Далее рекурсивно по всем потомкам if Node.HasChildren then begin for i := 0 to Node.Count-1 do UpdateStateIndex(Node[i]); end; end; |
Delphi. Иерархические данные. DBTreeView своими руками. Удаление потомков узла из TreeView
Удаление потомков узла. По логике, перед тем как вставить что-то новое желательно, удалить старые элементы узла.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
Процедуры очищения узла в дереве //----------------------------Очищение узла от всех потомков в дереве------------------------- procedure TCopyAndPasteThread.ClearNodeChildrenData(Node:TTreeNode); //Вспомогательная процедура - рекурсивно очищает память под Data под всеми узлами var i:integer; begin if not (MainForm.TreeView1.Selected=Node) then begin If Node.Data<>nil then Dispose(Node.Data); end; for i := 0 to Node.Count-1 do Self.ClearNodeChildrenData(Node[i]); end; procedure TCopyAndPasteThread.ClearAllChildren; //Непосредственное удаление из дерева var Node:TTreeNode; begin Node:=MainForm.TreeView1.Selected; ClearNodeChildrenData(Node); Node.DeleteChildren; end; |
Delphi. Иерархические данные. DBTreeView своими руками. Копирование узлов в TreeView с сохранением структуры
Это продолжение статьи про копирование узлов. В прошлом посте копировали иерархические записи в БД, в данном посте – будем обновлять узел в который вставляли скопированные записи. Эти 2 части – БД и TreeView должны работать синхронно – в этом самая … Continue reading
Delphi. Иерархические данные. DBTreeView своими руками. Копирование записей в БД с сохранением структуры
В данной статье посмотрим как копировать записи иерархических структур в DBTreeView, который мы уже на протяжении нескольких статей создаем своими руками. В этом посте только копирование записей в базе. В следующей добавлю обновление в дереве. Для меня задача оказалась нетривиальной. … Continue reading
Posted in Delphi, Без рубрики, Деревья
Comments Off on Delphi. Иерархические данные. DBTreeView своими руками. Копирование записей в БД с сохранением структуры
Delphi. Иерархические данные. DBTreeView своими руками. Делим узлы на папки и файлы
Продолжаю структурировать DBTreeView. Пришел к мысли, что в потоки следует убирать долгие операции, в моем случае – удаление множества узлов, отмечание галочками множества узлов. Короткие же достаточно поместить в обычный юнит – в частности добавление узлов. Данная статья посвящена специализации … Continue reading
Delphi. Иерархические данные. DBTreeView своими руками. Удаление “Checked” узлов в отдельном потоке
В данной статье описан алгоритм удаления узлов, отмеченных галочками в случае, когда дерево загружается динамически (то есть не полностью). Сам алгоритм работает из отдельного потока. Идея в том, чтобы собрать список “чекнутых” узлов, рекурсивно пройтись по базе, чтобы узнать есть … Continue reading