亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? diagram.pas

?? 類似文明的游戲源代碼。
?? PAS
字號(hào):
{$INCLUDE switches}

unit Diagram;

interface

uses
  BaseWin,

  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms,
  ButtonB, ButtonBase, Menus;

type
  TDiaDlg = class(TBaseDlg)
    CloseBtn: TButtonB;
    ToggleBtn: TButtonB;
    Popup: TPopupMenu;
    procedure CloseBtnClick(Sender: TObject);
    procedure FormPaint(Sender: TObject);
    procedure FormShow(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure ToggleBtnClick(Sender: TObject);
    procedure PlayerClick(Sender: TObject);
    procedure FormKeyDown(Sender: TObject; var Key: word;
      Shift: TShiftState);
  public
    Player: integer;
    Kind:(dkChart,dkShip);
    procedure OffscreenPaint; override;
  private
    Mode: integer;
  end;

var
  DiaDlg: TDiaDlg;

implementation

uses
Protocol, ScreenTools, ClientTools,Term;

{$R *.DFM}

const
Border=24;
RoundPixels: array[0..nStat-1] of integer=(10,10,10,5,5,5);

yArea=48;
xComp: array[0..5] of integer=(-60,-28,4,4,36,68);
yComp: array[0..5] of integer=(-40,-40,-79,-1,-40,-40);
xPow: array[0..3] of integer=(-116,-116,-116,-116);
yPow: array[0..3] of integer=(-28,0,-44,16);
xHab: array[0..1] of integer=(23,23);
yHab: array[0..1] of integer=(-81,1);

procedure TDiaDlg.FormCreate(Sender: TObject);
begin
inherited;
CaptionRight:=CloseBtn.Left;
CaptionLeft:=ToggleBtn.Left+ToggleBtn.Width;
InitButtons(self);
end;

procedure TDiaDlg.CloseBtnClick(Sender: TObject);
begin
Close;
end;

procedure TDiaDlg.OffscreenPaint;
type
TLine=array[0..99999,0..2] of Byte;
var
i,p,T,max,x,y,Stop,r,RoundRange,LineStep,nComp,nPow,nHab: integer;
s: string;
List: ^TChart;

  function Round(T: integer): integer;
  var
  n,i: integer;
  begin
  if T<RoundRange then n:=T else n:=RoundRange;
  result:=0;
  for i:=T-n to T do inc(result,List[i]);
  result:=result div (n+1);
  end;

  procedure ShareBar(x,y:integer; Cap:string; val0,val1: integer);
  begin
  LoweredTextOut(offscreen.Canvas,-1,InnerTex,x-2,y,Cap);
  DLine(offscreen.Canvas,x-2,x+169,y+16,InnerTex.clTextShade,
    InnerTex.clTextLight);
  if val0>0 then s:=Format(Phrases.Lookup('SHARE'),[val0,val1])
  else s:='0';
  RisedTextOut(offscreen.Canvas,x+170-offscreen.Canvas.TextWidth(s),y,s);
  end;

begin
inherited;
if Kind=dkChart then with offscreen.Canvas do
  begin
  Font.Assign(UniFont[ftTiny]);
  Font.Color:=$808080;

  RoundRange:=RoundPixels[Mode]*(MyRO.Turn-1) div (InnerWidth-2*Border);

  GetMem(List,4*(MyRO.Turn+1));
  if Mode=stExplore then max:=G.lx*G.ly
  else
    begin
    max:=-1;
    for p:=0 to nPl-1 do
      if (G.Difficulty[p]>0)
        and (Server(sGetChart+Mode shl 4,me,p,List^)>=rExecuted) then
        for T:=0 to MyRO.Turn-1 do
          begin r:=Round(T); if r>max then max:=r; end;
    end;

  Brush.Color:=$000000;
  FillRect(Rect(0,0,InnerWidth,InnerHeight));
  Brush.Style:=bsClear;
  Pen.Color:=$606060;
  MoveTo(Border,InnerHeight-Border);
  LineTo(InnerWidth-Border,InnerHeight-Border);
  if MyRO.Turn>=800 then LineStep:=200
  else if MyRO.Turn>=400 then LineStep:=100
  else LineStep:=50;
  for T:=0 to (MyRO.Turn-1) div LineStep do
    begin
    x:=Border+(InnerWidth-2*Border)*T*LineStep div (MyRO.Turn-1);
    MoveTo(x,Border);
    LineTo(x,InnerHeight-Border);
    s:=TurnToString(T*LineStep);
    Textout(x-TextWidth(s) div 2,Border-16,s);
    end;

  if max>0 then
    begin
    for p:=0 to nPl-1 do
      if (G.Difficulty[p]>0)
        and (Server(sGetChart+Mode shl 4,me,p,List^)>=rExecuted) then
        begin
        Pen.Color:=Tribe[p].Color;
        Stop:=MyRO.Turn-1;
        while (Stop>0) and (List[Stop]=0) do dec(Stop);
        for T:=0 to Stop do
          begin
          r:=Round(T);
          x:=Border+(InnerWidth-2*Border)*T div (MyRO.Turn-1);
          y:=InnerHeight-Border-(InnerHeight-2*Border)*r div max;
          if T=0 then MoveTo(x,y) else LineTo(x,y);
          end;
        end;
    end;
  FreeMem(List);
  Caption:=Phrases.Lookup('DIAGRAM',Mode);
  end
else with offscreen.Canvas do
  begin
  Font.Assign(UniFont[ftSmall]);
  Fill(offscreen.Canvas,0,0,InnerWidth,InnerHeight,0,0,InnerTex);
  Brush.Color:=$000000;
  FillRect(Rect(8,yArea,InnerWidth-8,yArea+200));
  Brush.Style:=bsClear;
  Frame(offscreen.Canvas,8-1,yArea-1,InnerWidth-8,yArea+200,InnerTex.clBevelShade,InnerTex.clBevelLight);
  RFrame(offscreen.Canvas,8-2,yArea-2,InnerWidth-8+1,yArea+200+1,InnerTex.clBevelShade,InnerTex.clBevelLight);

  // stars
  RandSeed:=Player*11111;
  for i:=1 to InnerWidth-16 do
    begin
    x:=Random((InnerWidth-16)*200);
    r:=Random(13)+28;
    Pixels[x div 200+8,x mod 200+yArea]:=(r*r*r*r div 10001)*$10101;
    end;

  nComp:=MyRO.Ship[Player].Parts[spComp];
  nPow:=MyRO.Ship[Player].Parts[spPow];
  nHab:=MyRO.Ship[Player].Parts[spHab];
  ShareBar(InnerWidth div 2-85,InnerHeight-62,Phrases.Lookup('SHIPHAB'),nHab,2);
  ShareBar(InnerWidth div 2-85,InnerHeight-43,Phrases.Lookup('SHIPPOW'),nPow,4);
  ShareBar(InnerWidth div 2-85,InnerHeight-24,Phrases.Lookup('SHIPCOMP'),nComp,6);
  if nComp>6 then nComp:=6;
  if nPow>4 then nPow:=4;
  if nHab>2 then nHab:=2;
  for i:=0 to nHab-1 do
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xHab[i],yArea+100+yHab[i],
      80,80,34,1);
  for i:=0 to nComp-1 do
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[i],yArea+100+yComp[i],
      32,80,1,1);
  if nComp>0 then
    for i:=3 downto nPow do
      Sprite(offscreen,HGrSystem2,InnerWidth div 2+xPow[i]+40,yArea+100+yPow[i],
        16,27,1,82);
  for i:=nPow-1 downto 0 do
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xPow[i],yArea+100+yPow[i],
      56,28,58,82);
  if (nComp<3) and (nHab>=1) then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[2]+32-16,yArea+100+7+yComp[2],
      16,27,1,82);
  if (nComp>=3) and (nHab<1) then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[2]+32,yArea+100+7+yComp[2],
      16,27,18,82);
  if (nComp<4) and (nHab>=2) then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[3]+32-16,yArea+100+46+yComp[3],
      16,27,1,82);
  if (nComp>=4) and (nHab<2) then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[3]+32,yArea+100+46+yComp[3],
      16,27,18,82);
  if (nComp<>6) and (nComp<>2) and not ((nComp=0) and (nPow<1)) then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[nComp],yArea+100+7+yComp[nComp],
      16,27,18,82);
  if (nComp<>6) and (nComp<>3) and not ((nComp=0) and (nPow<2)) then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[nComp],yArea+100+46+yComp[nComp],
      16,27,18,82);
  if nComp=2 then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[3],yArea+100+7+yComp[3],
      16,27,18,82);
  if nComp=3 then
    Sprite(offscreen,HGrSystem2,InnerWidth div 2+xComp[4],yArea+100+7+yComp[4],
      16,27,18,82);
  Caption:=Tribe[Player].TPhrase('TITLE_SHIP');
  end;
MarkUsedOffscreen(InnerWidth,InnerHeight);
end; // OffscreenPaint

procedure TDiaDlg.FormPaint(Sender: TObject);
begin
inherited;
BtnFrame(Canvas,CloseBtn.BoundsRect,OuterTex);
BtnFrame(Canvas,ToggleBtn.BoundsRect,OuterTex);
end;

procedure TDiaDlg.FormShow(Sender: TObject);
begin
if Kind=dkChart then
  begin
  Mode:=stPop;
  ToggleBtn.ButtonIndex:=15;
  end
else
  begin
  while MyRO.Ship[Player].Parts[spComp]+MyRO.Ship[Player].Parts[spPow]
    +MyRO.Ship[Player].Parts[spHab]=0 do
    Player:=(Player+1) mod nPl;
  ToggleBtn.ButtonIndex:=28;
  end;
OffscreenPaint;
end;

procedure TDiaDlg.ToggleBtnClick(Sender: TObject);
var
p1: integer;
m: TMenuItem;
begin
if Kind=dkChart then
  begin
  Mode:=(Mode+1) mod nStat;
  OffscreenPaint;
  Invalidate
  end
else
  begin
  while Popup.Items.Count>0 do Popup.Items.Delete(0);
  for p1:=0 to nPl-1 do
    if MyRO.Ship[p1].Parts[spComp]+MyRO.Ship[p1].Parts[spPow]
      +MyRO.Ship[p1].Parts[spHab]>0 then
      begin
      m:=TMenuItem.Create(Popup);
      m.RadioItem:=true;
      m.Caption:=Tribe[p1].TPhrase('TITLE_SHIP');
      m.Tag:=p1;
      m.OnClick:=PlayerClick;
      if p1=Player then m.Checked:=true;
      Popup.Items.Add(m);
      end;
  Popup.Popup(Left+ToggleBtn.Left, Top+ToggleBtn.Top+ToggleBtn.Height);
  end
end;

procedure TDiaDlg.PlayerClick(Sender: TObject);
begin
Player:=TComponent(Sender).Tag;
OffscreenPaint;
Invalidate
end;

procedure TDiaDlg.FormKeyDown(Sender: TObject; var Key: word;
  Shift: TShiftState);
begin
if (Key=VK_F8) and (Kind=dkChart) then ToggleBtnClick(nil)
else if Key=VK_ESCAPE then Close
end;

end.

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国模冰冰炮一区二区| 色婷婷精品久久二区二区蜜臂av | 久久国产欧美日韩精品| 久久久午夜精品理论片中文字幕| 色婷婷综合久色| 婷婷激情综合网| √…a在线天堂一区| 日韩美女一区二区三区四区| 91麻豆国产香蕉久久精品| 免费在线观看不卡| 亚洲午夜久久久久久久久久久 | www激情久久| 日本高清不卡视频| 国产91在线|亚洲| 极品销魂美女一区二区三区| 亚洲国产成人高清精品| 九九国产精品视频| 婷婷中文字幕一区三区| 亚洲精品国产一区二区三区四区在线| 亚洲人成精品久久久久| 亚洲嫩草精品久久| 一区二区三区色| 五月婷婷久久综合| 午夜精品久久久| 蜜臀a∨国产成人精品| 免费看日韩a级影片| 国产在线看一区| 成人高清视频免费观看| 欧美综合亚洲图片综合区| 欧美人狂配大交3d怪物一区| 日韩精品一区二区三区中文精品| 日韩一二三区不卡| 国产视频在线观看一区二区三区| 国产精品日韩成人| 亚洲欧美日韩人成在线播放| 欧美巨大另类极品videosbest | 亚洲va韩国va欧美va精品| 日本va欧美va精品| 粉嫩蜜臀av国产精品网站| 91在线国产福利| 日韩精品一区二区三区四区视频| 国产精品三级av在线播放| 亚洲一级二级三级在线免费观看| 免费人成黄页网站在线一区二区| 国产成人在线观看免费网站| 欧美色涩在线第一页| 2017欧美狠狠色| 亚洲欧美激情小说另类| 久久精品国产精品亚洲红杏| 日韩精品一区二| 亚洲激情中文1区| 懂色av一区二区夜夜嗨| 91精品国产综合久久蜜臀| 中文字幕亚洲视频| 国产自产高清不卡| 91精品国产入口| 国产精品国产三级国产有无不卡 | 色网站国产精品| 中文字幕不卡的av| 久久99最新地址| 欧美久久久久久久久中文字幕| 亚洲欧美视频在线观看视频| 福利电影一区二区三区| 久久综合九色综合97婷婷| 天堂久久一区二区三区| 色悠久久久久综合欧美99| 国产精品家庭影院| 国产成人亚洲精品青草天美| 精品一区二区三区在线播放| 欧美区在线观看| 亚洲国产精品影院| 在线观看视频一区二区 | 国产日韩av一区| 狠狠色狠狠色合久久伊人| 日韩欧美国产综合一区| 视频一区视频二区中文| 欧美日韩高清影院| 日本视频免费一区| 6080yy午夜一二三区久久| 婷婷中文字幕一区三区| 7878成人国产在线观看| 五月激情综合网| 日韩一区国产二区欧美三区| 美女一区二区视频| 精品日韩99亚洲| 国产a视频精品免费观看| 国产精品久久三| 欧洲日韩一区二区三区| 91福利资源站| 亚洲国产日韩av| 欧美成人伊人久久综合网| 成人激情免费电影网址| 亚洲专区一二三| 日韩欧美一区二区免费| 国产成人午夜视频| 亚洲人成人一区二区在线观看| 欧美日韩aaa| 精品国内片67194| 久久综合一区二区| 成人av电影在线| 一区二区欧美视频| 精品卡一卡二卡三卡四在线| 国产成人亚洲精品青草天美| 国产精品护士白丝一区av| 91免费观看视频| 奇米色一区二区| 久久精品亚洲一区二区三区浴池| 国产精品影视在线| 中文字幕色av一区二区三区| 亚洲国产综合人成综合网站| 日韩精品一区二| 97精品久久久午夜一区二区三区| 亚洲午夜精品17c| 26uuu亚洲综合色| 91久久精品网| 久久精品国产久精国产| 国产精品国产自产拍高清av| 7878成人国产在线观看| 国产在线精品免费av| 国产在线观看免费一区| 国产亚洲1区2区3区| 日本久久精品电影| 五月综合激情日本mⅴ| 国产日韩欧美a| 欧美日韩一级二级三级| 国产宾馆实践打屁股91| 午夜久久久久久电影| www精品美女久久久tv| 欧美日韩国产影片| 成人精品鲁一区一区二区| 亚洲国产视频一区二区| 国产一区二三区| 日韩精品三区四区| 日韩一区日韩二区| 久久久久亚洲蜜桃| 欧美日韩一区成人| 成人av资源站| 国产乱码精品一区二区三区av| 丝袜国产日韩另类美女| 亚洲精品亚洲人成人网| 久久精品亚洲精品国产欧美| 精品国产乱码久久久久久蜜臀| 666欧美在线视频| 国产精品污www在线观看| 日韩欧美国产系列| 91精品久久久久久蜜臀| 欧美日韩中文另类| 欧美性xxxxx极品少妇| 一本到不卡精品视频在线观看| 经典三级在线一区| 亚洲免费观看高清| 日韩欧美成人激情| 56国语精品自产拍在线观看| 欧美一级久久久久久久大片| 久久网这里都是精品| 亚洲精品网站在线观看| 午夜精品久久久久久久蜜桃app| 国产精品午夜在线| 欧美国产亚洲另类动漫| 国产精品视频yy9299一区| 国产精品欧美久久久久一区二区| 欧美电视剧在线看免费| 欧美日本在线一区| 日韩欧美国产wwwww| 91黄视频在线| 欧美福利一区二区| 亚洲精品成a人| 91成人免费网站| 56国语精品自产拍在线观看| 久久亚洲一级片| 亚洲久草在线视频| 日韩中文字幕亚洲一区二区va在线| 日本视频一区二区| 色综合久久中文字幕综合网| 精品国产91九色蝌蚪| 国产精品免费av| 99re66热这里只有精品3直播 | 欧美在线观看禁18| 日韩一区二区三区视频在线观看| 国产午夜久久久久| 亚洲一区二区不卡免费| 国产精品一区久久久久| 91成人国产精品| xnxx国产精品| 日韩不卡一区二区| 91视频91自| 久久综合给合久久狠狠狠97色69| 亚洲精品国产第一综合99久久| 久久爱www久久做| 欧美系列在线观看| 国产精品久久福利| 精品一区二区久久久| 欧美在线观看视频在线| 国产精品免费aⅴ片在线观看| 久久99久久久久| 欧美tickling挠脚心丨vk| 天堂在线亚洲视频| 欧美性猛交xxxx黑人交| 中文字幕一区二区三区在线观看 | 精品在线免费观看|