123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- program demo04;
- {$I zglCustomConfig.cfg}
- {$I zgl_config.cfg}
- {$R *.res}
- uses
- zgl_screen,
- zgl_window,
- zgl_timers,
- zgl_keyboard,
- zgl_font,
- zgl_text,
- zgl_sprite_2d,
- zgl_textures,
- zgl_textures_png,
- zgl_textures_jpg,
- zgl_utils
- {$IfNDef OLD_METHODS}
- , gegl_color
- {$EndIf}
- ;
- var
- dirRes : UTF8String {$IFNDEF MACOSX} = '../data/' {$ENDIF};
- fntMain : Byte;
- texBack : zglPTexture;
- procedure Init;
- begin
- fntMain := font_LoadFromFile(dirRes + 'font.zfi');
- texBack := tex_LoadFromFile(dirRes + 'back03.jpg');
- setTextColor(Get_Color(cl_White));
- setFontTextScale(15, fntMain);
- end;
- procedure Draw;
- begin
- ssprite2d_Draw(texBack, 0, 0, 800, 600, 0);
- text_Draw(fntMain, 0, 0, 'Escape - Exit' );
- text_Draw(fntMain, 0, 20 * 1, 'F1 - Fullscreen with desktop resolution and correction of aspect');
- text_Draw(fntMain, 0, 20 * 2, 'F2 - Fullscreen with desktop resolution and simple scaling');
- text_Draw(fntMain, 0, 20 * 3, 'F3 - Fullscreen with resolution 800x600');
- text_Draw(fntMain, 0, 20 * 4, 'F4 - Windowed mode');
- end;
- procedure KeyMouseEvent;
- begin
- // RU: Ðåêîìåíäóåìûé ê èñïîëüçîâàíèþ ïîëíîýêðàííûé ðåæèì. Îñíîâíàÿ èäåÿ - ïåðåêëþ÷èòüñÿ â ïîëíîýêðàííûé ðåæèì
- // èñïîëüçóÿ òåêóùåå ðàçðåøåíèå ðàáî÷åãî ñòîëà ïîëüçîâàòåëÿ, íî ïðè ýòîì
- // ñîõðàíèòü ïðîïîðöèè èçîáðàæåíèÿ. Ýòî ïîçâîëèò èçáåæàòü íåêîòîðûõ ïðîáëåì ñ LCD.
- // EN: Recommended fullscreen mode for using. Main idea is switching to fullscreen mode using current desktop resolution of user and saving the aspect. This will avoid some problems
- // with LCD's.
- if key_Press(K_F1) Then
- begin
- // RU: Âêëþ÷èòü êîððåêöèþ ïðîïîðöèé.
- // EN: Enable aspect correction.
- zgl_Enable(CORRECT_RESOLUTION);
- // RU: Óñòàíîâèòü ðàçðåøåíèå ïîä êîòîðîå èçíà÷àëüíî íàïèñàíî ïðèëîæåíèå.
- // EN: Set resolution for what application was wrote.
- scr_CorrectResolution(800, 600);
- zgl_SetParam(zgl_Get(DESKTOP_WIDTH), zgl_Get(DESKTOP_HEIGHT), True, false);
- (* --------------------- OR!!! ----------------------------------------
- wndWidth := zgl_Get( DESKTOP_WIDTH );
- wndHeight := zgl_Get( DESKTOP_HEIGHT );
- wndFullScreen := True;
- scrVSync := False;
- -------------------------------------------------------------------- *)
- scr_SetOptions();
- end;
- // RU: Ñõîæèé ðåæèì ñ ïðåäûäóùèì çà îäíèì èñêëþ÷åíèåì - îòêëþ÷åíà êîððåêöèÿ ïî øèðèíå è âûñîòå. Íàïðèìåð, îòêëþ÷åíèå êîððåêöèè ïî âûñîòå ìîæåò ïðèãîäèòüñÿ ïðè ñîîòîøåíèè
- // ñòîðîí 5:4(ðàçðåøåíèå ýêðàíà 1280x1024), ò.ê. ìîæíî çàïîëíèòü âñþ îáëàñòü ýêðàíà áåç ñóùåñòâåííûõ èñêàæåíèé.
- // EN: Similar mode to previous one with one exception - disabled correction for width and height. E.g. this can be useful for aspect 5:4(resolution 1280x1024),
- // because screen can be filled without significant distortion.
- if key_Press(K_F2) Then
- begin
- zgl_Enable(CORRECT_RESOLUTION);
- zgl_Disable(CORRECT_WIDTH);
- zgl_Disable(CORRECT_HEIGHT);
- scr_CorrectResolution(800, 600);
- { wndWidth := zgl_Get(DESKTOP_WIDTH);
- wndHeight := zgl_Get(DESKTOP_HEIGHT);
- wndFullScreen := true; }
- zgl_SetParam(zgl_Get(DESKTOP_WIDTH), zgl_Get(DESKTOP_HEIGHT), True, false);
- (* --------------------- OR!!! ----------------------------------------
- wndWidth := zgl_Get( DESKTOP_WIDTH );
- wndHeight := zgl_Get( DESKTOP_HEIGHT );
- wndFullScreen := True;
- scrVSync := False;
- -------------------------------------------------------------------- *)
- scr_SetOptions();
- end;
- // RU: Ïåðåêëþ÷åíèå â ïîëíîýêðàííûé ðåæèì èñïîëüçóÿ óêàçàííûå ðàçìåðû.  íàøå âðåìÿ òàêîé ïîäõîä èìååò äâà áîëüøèõ íåäîñòàòêà íà LCD:
- // - åñëè óêàçûâàåìîå ðàçðåøåíèå íå ÿâëÿåòñÿ ðîäíûì äëÿ LCD, òî áåç ñïåöèàëüíûõ íàñòðîéêàõ â äðàéâåðàõ ïîëüçîâàòåëü áóäåò íàáëþäàòü ïèêñåëèçàöèþ
- // - íà øèðîêîýêðàííûõ ìîíèòîðàõ êàðòèíêà ñ ñîîòíîøåíèåì 4:3 áóäåò ñìîòðåòñÿ ðàñòÿíóòîé
- // EN: Switching to fullscreen mode using set values. Nowadays this method two main problems with LCD:
- // - if used resolution is not main for LCD, then without special options in drivers user will see pixelization
- // - picture with aspect 4:3 will be stretched on widescreen monitors
- if key_Press(K_F3 ) Then
- begin
- zgl_Disable(CORRECT_RESOLUTION);
- zgl_SetParam(800, 600, true, false);
- (* ---------------------- OR!!! ----------------------------------------
- wndWidth := 800;
- wndHeight := 600;
- wndFullScreen := True;
- scrVSync := False;
- scr_SetOptions();
- -------------------------------------------------------------------- *)
- scr_SetOptions();
- end;
- // äëÿ ïîíèìàíèÿ, ðåæèì áåç êîððåêòèðîâêè - ýòî ðåàëüíûé ïîëíîýêðàííûé ðåæèì!!! Òî÷íåå - 1-é è 2-é ýòî îêîííûå ðåæèìû,
- // à òðåòèé - ýòî ïîëíîýêðàííûé.
- // À ýòî îçíà÷àåò, ÷òî åãî íàäî âûáèðàòü òîëüêî èç ñïèñêà ñóùåñòâóþùèõ âèäåîðåæèìîâ!!!
- // RU: Îêîííûé ðåæèì.
- // EN: Windowed mode.
- if key_Press(K_F4) Then
- begin
- zgl_Disable(CORRECT_RESOLUTION);
- (* ---------------------- OR!!! ----------------------------------------
- wndWidth := 800;
- wndHeight := 600;
- wndFullScreen := False;
- scrVSync := False;
- -------------------------------------------------------------------- *)
- zgl_SetParam(800, 600, False, false);
- scr_SetOptions();
- end;
- end;
- Begin
- zgl_Reg(SYS_EVENTS, @KeyMouseEvent);
- zgl_Reg( SYS_LOAD, @Init );
- zgl_Reg( SYS_DRAW, @Draw );
- wnd_SetCaption(utf8_Copy('04 - Screen Settings'));
- zgl_Init();
- End.
|