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

•  DeLiKaTeS Tetris (Тетрис)  4 643

•  TDictionary Custom Sort  6 646

•  Fast Watermark Sources  6 424

•  3D Designer  9 364

•  Sik Screen Capture  6 752

•  Patch Maker  7 142

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

•  ListBox Drag & Drop  6 010

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

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

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

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

•  Canvas Drawing  5 874

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

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

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

•  Paint on Shape  2 906

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

•  Головоломка Paletto  3 055

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

•  Пазл Numbrix  2 547

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

•  Игра HIP  2 230

•  Игра Go (Го)  2 163

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

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

•  Генератор лабиринта  2 679

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

•  HEX View  2 664

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

 
скрыть

  Форум  

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

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



Отображение ломанной линии



Автор: Jim Gunkel (Nevrona Designs)

Как мне вывести ломанную линию на холсте, если я не знаю размер массива (количество точек) до момента запуска программы??? По-моему, это невозможно. Просветите меня!

Недавно я решал аналогичную проблему при кодировании ReportPrinter и не нашел хорошего решения для создания открытого массива параметров заданного размера. Решение, которое я, наконец, использовал, заключалось в хитрой комбинации функции polyline и polygon с ассемблерным кодом. Я публикую исходный код, поскольку думаю что он будет полезен, пока Borland не создаст стандартные и простые методы для работы с массивами заданного размера.


type
  PPointArr = ^TPointArr;
  TPointArr = array[0..16380] of TPoint;

var
  I1: integer;
  Elements: word;
  PointArr: PPointArr;

begin
  GetMem(PointArr, (Elements + 1) * SizeOf(TPoint));
  try
    for I1 := 0 to Elements do
    begin
      PointArr^[I1].X := ReadNextXValue;
      PointArr^[I1].Y := ReadNextYValue;
    end; { for }

    { Вызов Polygon(PointArr^), но только с Elements+1-элеменами
      в открытом массиве }
    asm
      les di,PointArr { Помещаем указатель на PointArr }
      push es
      push di
      push Elements { Помещаем High(PointArr^) }
      les di,self { Помещаем указатель self }
      push es
      push di
      les di,es:[di] { Вызов self.Polygon }
      call Polygon
    end; { asm }
  finally
    FreeMem(PointArr, (Elements + 1) * SizeOf(TPoint));
  end; { try }
end;


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

Группа ВКонтакте