-
MY PROJECTS
-
Recent Posts
- SpringBoot.Making our first starter and autoconfiguration
- Spring. Creating main annotation to start business logic
- Spring.Reading from properties file
- Spring.How to define spring version inside springBoot ?
- SpringBoot App inside Docker
- Kafka.FirstExperience
- Docker.MySql and Lost connection to MySQL server at ‘reading initial communication packet’, system error: 0
- Gradle.Tips
- Spring.AppConfig
- Leetcode.Best-time-to-buy-and-sell-stock
- LeetCode.ClimbStairs.Fibbonacci
- Leetcode.Roman-to-integer
- LeetCode.Palindrome-number
- Java.DesignPatterns.Lightweight
- Java.DesignPatterns.Proxy
- Java.DesignPatterns.Facade
- Java.DesignPatterns.Composite
- Java.DesignPatterns.Bridge
- Java. Strange OOP thing
- Java.Classpath
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)
- Регулярные выражения
- Тестирование приложений
Monthly Archives: April 2016
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. MySQL. Копирование записи
Часто встречается такая задача, чтобы не искать долго по интернетам, решил вывести её решение в отдельный пост. Решение задачи базируется на удобной возможности MySQL Insert… Select…
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 37 |
//---------------------------------Копирование записей в БД----------------------------- function CopyRecordInDB(SourceID: integer): integer; var qSelectInsert: TFDQuery; qGetKey: TFDQuery; begin qSelectInsert := TFDQuery.Create(nil); try qSelectInsert.Connection := FDConnection; qSelectInsert.SQL.Text:= 'INSERT INTO `treeview_db`.`tree`'+ '(`IdParent`,'+ '`Name`,'+ '`Index`,'+ '`isChecked`,'+ '`IsExpanded`,'+ '`Level`,'+ '`IsFolder`)'+ 'SELECT'+ '`IdParent`,'+ '`Name`,'+ '`Index`,'+ '`isChecked`,'+ '`IsExpanded`,'+ '`Level`,'+ '`IsFolder`'+ ' from'+ '`treeview_db`.`tree` where id = :id' ; qSelectInsert.Params.ParamValues['id'] := SourceId; qSelectInsert.ExecSQL; finally qSelectInsert.Free; end; 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