Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Графика и игры
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
  #19  
Старый 31.08.2012, 14:45
Аватар для poli-smen
poli-smen poli-smen вне форума
Профессионал
 
Регистрация: 06.08.2012
Адрес: Кривой Рог
Сообщения: 1,791
Версия Delphi: Delphi 7, XE2
Репутация: 4415
По умолчанию

"По просьбам трудящихся" наваял пример рисующий некую 3D-гистограмму на основе bmp-файла:
Код:
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
procedure TForm1.ButtonClick(Sender: TObject);
var
  bmp: TBitmap;
  BmpX, BmpY, X, Y, Z, TempX, TempY, BmpHalfWidth, BmpHalfHeight, Radius: Integer;
  Color: TColor;
  A, SinA, CosA, B, SinB, CosB, DY: Extended;
begin
  bmp := TBitmap.Create;
  try
    bmp.LoadFromFile('C:\WINDOWS\Ночной ковыль.bmp');
//    bmp.LoadFromFile('C:\WINDOWS\Пузыри.bmp');
//    bmp.LoadFromFile('C:\WINDOWS\Рододендрон.bmp');
 
    BmpHalfWidth := bmp.Width div 2;
    BmpHalfHeight := bmp.Height div 2;
    Radius := Trunc(Sqrt(Sqr(bmp.Width) + Sqr(bmp.Height)) / 2);
 
    A := DegToRad(30);
    SinA := Sin(A);
    CosA := Cos(A);
 
    B := DegToRad(20);
    SinB := Sin(B);
    CosB := Cos(B);
 
    DY := 256 * CosB;
 
    Repaint;
 
    for BmpY := 0 to bmp.Height - 1 do
    begin
      for BmpX := 0 to bmp.Width - 1 do
      begin
        Color := bmp.Canvas.Pixels[BmpX, BmpY];
        Z := (GetRValue(Color) + GetGValue(Color) + GetBValue(Color)) div 3;
 
        TempX := BmpX - BmpHalfWidth;
        TempY := BmpY - BmpHalfHeight;
 
        X := Trunc(TempX * CosA + TempY * SinA + Radius);
        Y := Trunc((TempY * CosA - TempX * SinA) * SinB + Radius + DY);
 
        Canvas.Pen.Color := Color;
        Canvas.MoveTo(X, Y);
        Canvas.LineTo(X, Y - Trunc(Z * CosB));
      end;
    end;
  finally
    bmp.Free;
  end;
end;
В этом примере высота столбика гистограммы просто среднее арифметическое значение трёх составляющих цвета пикселя.
Ответить с цитированием
Этот пользователь сказал Спасибо poli-smen за это полезное сообщение:
zibert (01.09.2012)
 


Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 08:30.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025