Недавно добавленные исходники

•  3D Designer  829

•  Sik Screen Capture  572

•  Patch Maker  513

•  Айболит (remote control)  628

•  ListBox Drag & Drop  465

•  Доска для игры Реверси  8 589

•  Графические эффекты  561

•  Рисование по маске  441

•  Перетаскивание изображений  487

•  Canvas Drawing  488

•  Рисование Луны  380

•  Поворот изображения  260

•  Рисование стержней  315

•  Paint on Shape  189

•  Генератор кроссвордов  247

•  Головоломка Paletto  225

•  Теорема Монжа об окружностях  270

•  Пазл Numbrix  185

•  Заборы и коммивояжеры  302

•  Игра HIP  204

•  Игра Go (Го)  145

•  Симулятор лифта  180

•  Программа укладки плитки  165

•  Генератор лабиринта  204

•  Проверка числового ввода  193

•  HEX View  231

•  Физический маятник  202

•  Задача коммивояжера  233

•  Автомобильная пробка  156

•  Квадратные сетки из слов  127

 
скрыть


Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Методы Assign и AssignTo написаны для типов TStrings и TListItems



Автор: Максим Игнатьев

Вариант решения :

Публикуется только в части предмета задания. Полный вариант проекта - Lists2.zip (6.7K)
procedure TNamedHCollection.AssignTo(Dest: TPersistent);
var
  i, c: integer;
  TN: TTreeNode;
begin
  ...
    // Заветное решение для дерева.
  if Dest is TTreeNodes then
    with TTreeNodes(Dest) do
    begin
      BeginUpdate;
      Clear;
      for i := 0 to Self.Count - 1 do
      begin
        TN := AddChild(nil, Items[i].Name);
        TN.Assign(Items[i].Items);
      end;
      EndUpdate;
      exit;
    end;
  if Dest is TTreeNode then
    with TTreeNode(Dest) do
    begin
      for i := 0 to Self.Count - 1 do
      begin
        TN := Owner.AddChild(TTreeNode(Dest), Items[i].Name);
        TN.Assign(Items[i].Items);
      end;
      exit;
    end;
  inherited;
end;

procedure TNamedHCollection.Assign(Source: TPersistent);
var
  i: integer;
  FItem: TNamedHCollectionItem;
  TN, NN: TTreeNode;
begin
  .....
    // Заветное решение для дерева.
  if Source is TTreeNodes then
  begin
    Assign(TTreeNodes(Source).GetFirstNode);
    exit;
  end;
  if Source is TTreeNode then
  begin
    TN := TTreeNode(Source);
    while TN <> nil do
    begin
      FItem := Self.Add;
      FItem.Name := TN.Text;
      NN := TN.GetFirstChild;
      if Assigned(NN) then
        FItem.Items.Assign(NN);
      TN := TN.getNextSibling;
    end;
    exit;
  end;
  inherited;
end;




Похожие по теме исходники

Assign Files

Нейросеть для распознавания образов

Механизм станка качалки для нефти

Весы для взвешивания

 

Кувшины для воды

Доска для игры Реверси




Copyright © 2004-2021 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте   Facebook   Ссылка на Twitter   Ссылка на Telegram