Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.09.05;
Скачать: CL | DM;

Вниз

Размеры повернутого битмапа   Найти похожие ветки 

 
dimon_programmer   (2004-06-14 19:08) [0]

Здраствуйте! Подскажите вот какую вешь: как узнать минимальные размеры битмапа, в который влезет
битмап размером W на H, повернутый на N градусов. Я пробую находить минимальный и максимальный Х и У,
а затем находить разность, но при больших углах этот способ выдает ерунду.


 
Fenik   (2004-06-14 21:54) [1]

type TRectList = array [1..4] of TPoint;

function RotateRect(const Rect: TRect; const Center: TPoint; Angle: Double): TRectList;
var DX, DY: Integer;
   SinAng, CosAng: Double;

 procedure SinCos(AngleRad: Double; var ASin, ACos: Double);
 begin
   ASin := Sin(AngleRad);
   ACos := Cos(AngleRad);
 end;

 function RotPoint(PX, PY: Integer): TPoint;
 begin
   DX := PX - Center.x;
   DY := PY - Center.y;
   Result.x := Center.x + Round(DX * CosAng - DY * SinAng);
   Result.y := Center.y + Round(DX * SinAng + DY * CosAng);
 end;

begin
 SinCos(Angle * (Pi / 180), SinAng, CosAng);
 Result[1] := RotPoint(Rect.Left, Rect.Top);
 Result[2] := RotPoint(Rect.Right, Rect.Top);
 Result[3] := RotPoint(Rect.Right, Rect.Bottom);
 Result[4] := RotPoint(Rect.Left, Rect.Bottom);
end;

function Min(A, B: Integer): Integer;
begin
 if A < B then Result := A
          else Result := B;
end;

function Max(A, B: Integer): Integer;
begin
 if A > B then Result := A
          else Result := B;
end;

function GetRLLimit(const RL: TRectList): TRect;
begin
 Result.Left   := Min(Min(RL[1].x, RL[2].x), Min(RL[3].x, RL[4].x));
 Result.Top    := Min(Min(RL[1].y, RL[2].y), Min(RL[3].y, RL[4].y));
 Result.Right  := Max(Max(RL[1].x, RL[2].x), Max(RL[3].x, RL[4].x));
 Result.Bottom := Max(Max(RL[1].y, RL[2].y), Max(RL[3].y, RL[4].y));
end;

var Lim: TRect;

   Lim := GetRLLimit(RotateRect(Rect(0, 0, W, H), Point(0, 0), Angle));
   NewW := Lim.Right - Lim.Left;
   NewH := Lim.Bottom - Lim.Top;


Попробуй упростить.


 
Огромное Кулясище   (2004-06-14 22:31) [2]

Alpha := Alpha * 3.14159265358979 / 180;

Sx := Abs(SrcR * Cos(Alpha)) + Abs(SrcB * Sin(Alpha));
Sy := Abs(SrcR * Sin(Alpha)) + Abs(SrcB * Cos(Alpha));

Sx, Sy - ответ. Alpha - угол в градусах.


 
Fenik   (2004-06-14 22:45) [3]

>Огромное Кулясище  (14.06.04 22:31) [2]

О! Именно так.


 
Огромное Кулясище   (2004-06-14 22:54) [4]

Забыл пояснить, что ScrR и ScrB - это ширина и высота соответсвенно (т.е. ScrR - ширина).



Страницы: 1 вся ветка

Текущий архив: 2004.09.05;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.03 c
1-1092954505
Profi
2004-08-20 02:28
2004.09.05
Загрузка файла


4-1090329440
Rem
2004-07-20 17:17
2004.09.05
Ловушки для активИксов


14-1091360013
vidiv
2004-08-01 15:33
2004.09.05
Будет ли такое работать в ТУРБО Паскале.


6-1088658782
Артем К.
2004-07-01 09:13
2004.09.05
Присутствует ли в сети компьютер с введенным в edit IP-адресу


1-1092860381
nester
2004-08-19 00:19
2004.09.05
Что делать с локальными типизироваными константами в Делфи 7