Главная страница
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.042 c
1-1092916718
han-bratan
2004-08-19 15:58
2004.09.05
как добавить пункт меню из DLL ?


14-1092605401
Baron
2004-08-16 01:30
2004.09.05
Фотоприколы


1-1092833472
Leaner
2004-08-18 16:51
2004.09.05
Является файл ShortCut-ом или нет ?


1-1093168480
Jiurasrasr
2004-08-22 13:54
2004.09.05
Как обеспечить чтобы окно было повнрх всех!


14-1092362894
Думкин
2004-08-13 06:08
2004.09.05
С днем рождения! 13 августа