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

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

?? reportcontrol.~pa

?? 國產(chǎn)的報表控件
?? ~PA
?? 第 1 頁 / 共 5 頁
字號:
         FCellrect.Left :=FCellrect.Left * 100 div Scale;
         FCellrect.top :=FCellrect.top * 100 div Scale;
         FCellrect.right :=FCellrect.right * 100 div Scale;
         FCellrect.bottom :=FCellrect.bottom * 100 div Scale;
        end;
}
    // 計算文本框的矩形
    TempRect := FCellRect;

    TempRect.left := TempRect.Left + FLeftMargin + 1;
    TempRect.top := TempRect.top + FTopLineWidth + 1;
    TempRect.right := TempRect.right - FLeftMargin - 1;
    TempRect.bottom := TempRect.top + FMinCellHeight - 2 - FTopLineWidth - FBottomLineWidth;

    case FVertAlign of
      TEXT_ALIGN_VCENTER:
        begin
          TempRect.Top := TempRect.Top + trunc((OwnerLineHeight - FMinCellHeight) / 2 + 0.5);
          TempRect.Bottom := TempRect.Bottom + trunc((OwnerLineHeight - FMinCellHeight) / 2 + 0.5);
        end;
      TEXT_ALIGN_BOTTOM:
        begin
          TempRect.Top := TempRect.Top + OwnerLineHeight - FMinCellHeight;
          TempRect.Bottom := TempRect.Bottom + OwnerLineHeight - FMinCellHeight;
        end;
    end;
{        if Scale <> 100 then
        begin
         temprect.top := temprect.top * 100 div Scale;
         temprect.bottom :=temprect.Bottom  * 100 div Scale;
         temprect.Left  := temprect.left * 100 div Scale;
         temprect.Right  := temprect.Right  * 100 div Scale;
        end;
}
    FTextRect := TempRect;
  end
  else
  begin
    TotalHeight := OwnerLineHeight;

    for I := 0 to FCellsList.Count - 1 do
      TotalHeight := TotalHeight + TReportCell(FCellsList[I]).OwnerLineHeight;

    FCellRect.left := FCellLeft;
    FCellRect.top := CellTop;
    FCellRect.right := FCellRect.left + FCellWidth;
    FCellRect.bottom := FCellRect.top + TotalHeight;

    // 計算文本框的矩形
    TempRect := FCellRect;

    TempRect.left := TempRect.Left + FLeftMargin + 1;
    TempRect.top := TempRect.top + FTopLineWidth + 1;
    TempRect.right := TempRect.right - FLeftMargin;
    TempRect.bottom := TempRect.top + FRequiredCellHeight - 2 - FTopLineWidth - FBottomLineWidth;

    case FVertAlign of
      TEXT_ALIGN_VCENTER:
        begin
          TempRect.Top := TempRect.Top + trunc((FCellRect.Bottom - FCellRect.Top - FRequiredCellHeight) / 2 + 0.5);
          TempRect.Bottom := TempRect.Bottom + trunc((FCellRect.Bottom - FCellRect.Top - FRequiredCellHeight) / 2 + 0.5);
        end;
      TEXT_ALIGN_BOTTOM:
        begin
          TempRect.Top := TempRect.Top + FCellRect.Bottom - FCellRect.Top - FRequiredCellHeight;
          TempRect.Bottom := TempRect.Bottom + FCellRect.Bottom - FCellRect.Top - FRequiredCellHeight;
        end;
    end;
{
        if Scale <> 100 then
        begin
         temprect.top := temprect.top * 100 div Scale;
         temprect.bottom :=temprect.Bottom  * 100 div Scale;
         temprect.Left  := temprect.left * 100 div Scale;
         temprect.Right  := temprect.Right  * 100 div Scale;
        end;
}
    FTextRect := TempRect;
  end;
end;

procedure TReportCell.PaintCell(hPaintDC: HDC; bPrint: Boolean);
var
  SaveDCIndex: Integer;
  hTempBrush: HBRUSH;
  TempLogBrush: TLOGBRUSH;
  hGrayPen, hPrevPen, hTempPen: HPEN;
  bDelete: Boolean;
  Format: UINT;
  hTextFont, hPrevFont: HFONT;
  TempRect: TRect;
begin
  if FOwnerCell <> nil then
    Exit;

  SaveDCIndex := SaveDC(hPaintDC);

  SetBkMode(hPaintDC, TRANSPARENT);

  // 繪制底色
  TempRect := FCellRect;
  TempRect.Top := TempRect.Top + 1;
  TempRect.Right := TempRect.Right + 1;
  if FBackGroundColor <> RGB(255, 255, 255) then
  begin
    TempLogBrush.lbStyle := BS_SOLID;
    TempLogBrush.lbColor := FBackGroundColor;
    hTempBrush := CreateBrushIndirect(TempLogBrush);
    FillRect(hPaintDC, TempRect, hTempBrush);
    DeleteObject(hTempBrush);
  end;

  // 繪制邊框
  hGrayPen := CreatePen(BS_SOLID, 1, RGB(192, 192, 192));

  // 左邊線
  if not bPrint and (FLeftLine or (FCellIndex = 0)) then
  begin
    bDelete := False;
    hTempPen := hGrayPen;
    if FLeftLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FLeftLineWidth, RGB(0, 0, 0));
      bDelete := True;
    end;

    hPrevPen := SelectObject(hPaintDc, hTempPen);

    MoveToEx(hPaintDc, FCellRect.left, FCellRect.top, nil);
    LineTo(hPaintDC, FCellRect.left, FCellRect.bottom);

    SelectObject(hPaintDc, hPrevPen);

    if bDelete then
      DeleteObject(hTempPen);
  end
  else
  begin
    if FLeftLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FLeftLineWidth, RGB(0, 0, 0));
      hPrevPen := SelectObject(hPaintDc, hTempPen);

      MoveToEx(hPaintDc, FCellRect.left, FCellRect.top, nil);
      LineTo(hPaintDC, FCellRect.left, FCellRect.bottom);

      SelectObject(hPaintDc, hPrevPen);
      DeleteObject(hTempPen);
    end;
  end;

  // 上邊線
  if not bPrint and (FTopLine or (OwnerLine.Index = 0)) then
  begin
    bDelete := False;
    hTempPen := hGrayPen;

    if FTopLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FTopLineWidth, RGB(0, 0, 0));
      bDelete := True;
    end;

    hPrevPen := SelectObject(hPaintDC, hTempPen);

    MoveToEx(hPaintDc, FCellRect.left, FCellRect.top, nil);
    LineTo(hPaintDc, FCellRect.right, FCellRect.top);

    SelectObject(hPaintDc, hPrevPen);

    if bDelete then
      DeleteObject(hTempPen);
  end
  else
  begin
    if FTopLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FTopLineWidth, RGB(0, 0, 0));
      hPrevPen := SelectObject(hPaintDc, hTempPen);

      MoveToEx(hPaintDc, FCellRect.left, FCellRect.top, nil);
      LineTo(hPaintDc, FCellRect.right, FCellRect.top);

      SelectObject(hPaintDc, hPrevPen);
      DeleteObject(hTempPen);
    end;
  end;


  // 右邊線
  if not bPrint then
  begin
    bDelete := False;
    hTempPen := hGrayPen;

    if FRightLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FRightLineWidth, RGB(0, 0, 0));
      bDelete := True;
    end;

    hPrevPen := SelectObject(hPaintDc, hTempPen);

    MoveToEx(hPaintDc, FCellRect.right, FCellRect.top, nil);
    LineTo(hPaintDC, FCellRect.right, FCellRect.bottom);

    SelectObject(hPaintDc, hPrevPen);

    if bDelete then
      DeleteObject(hTempPen);
  end
  else
  begin
    if FRightLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FRightLineWidth, RGB(0, 0, 0));
      hPrevPen := SelectObject(hPaintDc, hTempPen);

      MoveToEx(hPaintDc, FCellRect.right, FCellRect.top, nil);
      LineTo(hPaintDC, FCellRect.right, FCellRect.bottom);

      SelectObject(hPaintDc, hPrevPen);
      DeleteObject(hTempPen);
    end;
  end;


  // 下邊線
  if not bPrint then
  begin
    bDelete := False;
    hTempPen := hGrayPen;

    if FBottomLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FBottomLineWidth, RGB(0, 0, 0));
      bDelete := True;
    end;

    hPrevPen := SelectObject(hPaintDc, hTempPen);

    MoveToEx(hPaintDc, FCellRect.left, FCellRect.bottom, nil);
    LineTo(hPaintDc, FCellRect.right, FCellRect.bottom);

    SelectObject(hPaintDc, hPrevPen);

    if bDelete then
      DeleteObject(hTempPen);
  end
  else
  begin
    if FBottomLine then
    begin
      hTempPen := CreatePen(PS_SOLID, FBottomLineWidth, RGB(0, 0, 0));
      hPrevPen := SelectObject(hPaintDc, hTempPen);

      MoveToEx(hPaintDc, FCellRect.left, FCellRect.bottom, nil);
      LineTo(hPaintDc, FCellRect.right, FCellRect.bottom);

      SelectObject(hPaintDc, hPrevPen);
      DeleteObject(hTempPen);
    end;
  end;


  DeleteObject(hGrayPen);

  hTempPen := CreatePen(PS_SOLID, 1, RGB(0, 0, 0));
  hPrevPen := SelectObject(hPaintDc, hTempPen);

  // 繪制斜線
  if FDiagonal > 0 then
  begin
    if ((FDiagonal and LINE_LEFT1) > 0) then
    begin
      MoveToEx(hPaintDC, FCellRect.left + 1, FCellRect.top + 1, nil);
      LineTo(hPaintDC, FCellRect.right - 1, FCellRect.bottom - 1);
    end;

    if ((FDiagonal and LINE_LEFT2) > 0) then
    begin
      MoveToEx(hPaintDC, FCellRect.left + 1, FCellRect.top + 1, nil);
      LineTo(hPaintDC, FCellRect.right - 1, trunc((FCellRect.bottom + FCellRect.top) / 2 + 0.5));
    end;

    if ((FDiagonal and LINE_LEFT3) > 0) then
    begin
      MoveToEx(hPaintDC, FCellRect.left + 1, FCellRect.top + 1, nil);
      LineTo(hPaintDC, trunc((FCellRect.right + FCellRect.left) / 2 + 0.5), FCellRect.bottom - 1);
    end;

    if ((FDiagonal and LINE_RIGHT1) > 0) then
    begin
      MoveToEx(hPaintDC, FCellRect.right - 1, FCellRect.top + 1, nil);
      LineTo(hPaintDC, FCellRect.left + 1, FCellRect.bottom - 1);
    end;

    if ((FDiagonal and LINE_RIGHT2) > 0) then
    begin
      MoveToEx(hPaintDC, FCellRect.right - 1, FCellRect.top + 1, nil);
      LineTo(hPaintDC, FCellRect.left + 1, trunc((FCellRect.bottom + FCellRect.top) / 2 + 0.5));
    end;

    if ((FDiagonal and LINE_RIGHT3) > 0) then
    begin
      MoveToEx(hPaintDC, FCellRect.right - 1, FCellRect.top + 1, nil);
      LineTo(hPaintDC, trunc((FCellRect.right + FCellRect.left) / 2 + 0.5), FCellRect.bottom - 1);
    end;

  end;

  SelectObject(hPaintDC, hPrevPen);
  DeleteObject(hTempPen);

  // 繪制文字
  if Length(FCellText) > 0 then
  begin
    Windows.SetTextColor(hPaintDC, FTextColor);
    Format := DT_EDITCONTROL or DT_WORDBREAK;
    case FHorzAlign of
      TEXT_ALIGN_LEFT:
        Format := Format or DT_LEFT;
      TEXT_ALIGN_CENTER:
        Format := Format or DT_CENTER;
      TEXT_ALIGN_RIGHT:
        Format := Format or DT_RIGHT;
    else
      Format := Format or DT_LEFT;
    end;

    hTextFont := CreateFontIndirect(FLogFont);
    hPrevFont := SelectObject(hPaintDC, hTextFont);
    TempRect := FTextRect;
    DrawText(hPaintDC, PChar(FCellText), Length(FCellText), TempRect, Format);
    SelectObject(hPaintDC, hPrevFont);
    DeleteObject(hTextFont);
  end;

  RestoreDC(hPaintDC, SaveDCIndex);
end;

constructor TReportCell.Create;
var
  hTempDC: HDC;
  pt, ptOrg: TPoint;
begin
  FCellsList := TList.Create;
  FLeftMargin := 5;
  FOwnerLine := nil;
  FOwnerCell := nil;

  FCellIndex := -1;

  FCellLeft := 0;
  FCellWidth := 0;

  FCellRect.Left := 0;
  FCellRect.Top := 0;
  FCellRect.Right := 0;
  FCellRect.Bottom := 0;

  FTextRect.Left := 0;
  FTextRect.Top := 0;
  FTextRect.Right := 0;
  FTextRect.Bottom := 0;

  FDragCellHeight := 0;
  FMinCellHeight := 0;
  FRequiredCellHeight := 0;

  // border
  FLeftLine := True;
  FLeftLineWidth := 1;

  FTopLine := True;
  FTopLineWidth := 1;

  FRightLine := True;
  FRightLineWidth := 1;

  FBottomLine := True;
  FBottomLineWidth := 1;

  // 斜線
  FDiagonal := 0;

  // color
  FTextColor := RGB(0, 0, 0);
  FBackGroundColor := RGB(255, 255, 255);

  // align
  FHorzAlign := TEXT_ALIGN_LEFT;
  FVertAlign := TEXT_ALIGN_CENTER;

  // string
  FCellText := '';

  // font
  FLogFont.lfHeight := 120;
  FLogFont.lfWidth := 0;
  FLogFont.lfEscapement := 0;
  FLogFont.lfOrientation := 0;
  FLogFont.lfWeight := 0;
  FLogFont.lfItalic := 0;
  FLogFont.lfUnderline := 0;
  FLogFont.lfStrikeOut := 0;
  FLogFont.lfCharSet := DEFAULT_CHARSET;
  FLogFont.lfOutPrecision := 0;
  FLogFont.lfClipPrecision := 0;
  FLogFont.lfQuality := 0;
  FLogFont.lfPitchAndFamily := 0;
  FLogFont.lfFaceName := '宋體';

  // Hey, I pass a invalid window's handle to you, what you return to me ?
  // Haha, is a device context of the DESKTOP WINDOW !
  hTempDC := GetDC(0);

  pt.y := GetDeviceCaps(hTempDC, LOGPIXELSY) * FLogFont.lfHeight;
  pt.y := trunc(pt.y / 720 + 0.5); // 72 points/inch, 10 decipoints/point
  DPtoLP(hTempDC, pt, 1);
  ptOrg.x := 0;
  ptOrg.y := 0;
  DPtoLP(hTempDC, ptOrg, 1);
  FLogFont.lfHeight := -abs(pt.y - ptOrg.y);
  ReleaseDC(0, hTempDC);

end;

destructor TReportCell.Destroy;
begin
  FCellsList.Free;
  FCellsList := nil;

  inherited Destroy;
end;

function TReportCell.GetOwnerLineHeight: Integer;
begin
  if FOwnerLine = nil then
    Result := 0
  else
    Result := FOwnerLine.LineHeight;
end;

procedure TReportCell.CopyCell(Cell: TReportCell; bInsert: Boolean);
begin
  FLeftMargin := Cell.FLeftMargin;

  // Index
  FCellIndex := Cell.FCellIndex;

  // size & position
  FCellLeft := Cell.FCellLeft;
  FCellWidth := Cell.FCellWidth;

  FCellRect.Left := 0;
  FCellRect.Top := 0;
  FCellRect.Right := 0;
  FCellRect.Bottom := 0;

  FTextRect.Left := 0;
  FTextRect.Top := 0;
  FTextRect.Right := 0;
  FTextRect.Bottom := 0;

  FDragCellHeight := Cell.FDragCellHeight;
  FMinCellHeight := Cell.FMinCellHeight;

  // border
  FLeftLine := Cell.FLeftLine;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级黄色大片| 免费视频最近日韩| 无码av免费一区二区三区试看| 午夜精品福利在线| 国内外成人在线| 91在线观看污| 日韩一区二区三区免费观看| 国产欧美日韩在线| 亚洲精品中文在线影院| 精品久久一区二区三区| 日韩一区二区视频| 久久久美女毛片| 中文字幕中文字幕在线一区 | 粉嫩嫩av羞羞动漫久久久| 国产成人啪免费观看软件| 成人免费av在线| 欧美在线一区二区| 欧美精品一区二区不卡| 国产视频视频一区| 一区二区三区波多野结衣在线观看| 日韩电影在线一区| 国产精品一区一区三区| 制服丝袜日韩国产| 成人午夜av电影| 国产一区福利在线| 91麻豆精品秘密| 国产日韩精品久久久| 色综合一区二区| 日本不卡一二三| 亚洲综合精品自拍| 国产综合色产在线精品| 欧美性猛交一区二区三区精品| 久久久亚洲精品石原莉奈| 亚洲一区二区视频在线观看| 国产福利91精品一区| 欧美一区二区三区在| 亚洲欧美成aⅴ人在线观看| 91久久奴性调教| 日韩欧美国产电影| 一区二区三区在线视频观看 | 亚洲色图.com| 亚洲色图在线视频| 紧缚捆绑精品一区二区| 欧美年轻男男videosbes| 91精品福利在线一区二区三区 | 一区二区三区免费在线观看| 国产在线精品一区在线观看麻豆| 欧美日韩亚洲综合一区二区三区| 国产精品传媒入口麻豆| 久久综合综合久久综合| 欧美午夜精品久久久久久超碰| 国产精品伦理一区二区| 九一九一国产精品| 欧美精品精品一区| 一区二区三区在线观看视频| 成人丝袜视频网| 久久久国产精品午夜一区ai换脸| 毛片av一区二区| 欧美精品日韩一区| 一区二区三区久久久| 97se亚洲国产综合在线| 国产精品私房写真福利视频| 国产成人精品一区二| 欧美mv日韩mv亚洲| 日日夜夜精品视频天天综合网| 国产精品国产三级国产aⅴ入口| 91亚洲男人天堂| 国产高清在线观看免费不卡| 国产日韩一级二级三级| 成人av一区二区三区| 亚洲一线二线三线久久久| 色诱视频网站一区| 美女在线视频一区| 日本一区二区成人| 欧美日韩精品一区二区三区蜜桃| 国产呦萝稀缺另类资源| 日韩欧美一级精品久久| 亚洲成人一区在线| 欧美色爱综合网| 午夜影视日本亚洲欧洲精品| 欧美丰满嫩嫩电影| 午夜视黄欧洲亚洲| 日韩午夜在线观看视频| 青青草伊人久久| 精品国产乱码久久久久久老虎| 91免费观看在线| 欧美日韩日本视频| 日韩国产高清影视| 日韩视频一区二区三区在线播放| 久久精品国产亚洲a| 欧美一级精品大片| 国产精品资源在线看| 欧美国产激情二区三区| 色综合色综合色综合| 亚洲一区在线观看网站| 欧美日韩的一区二区| 久久99在线观看| 国产精品久久久久久久久快鸭| 色综合久久综合网欧美综合网| 亚洲国产精品久久久男人的天堂| 欧美一级电影网站| 国产一区二区毛片| 中文字幕视频一区| 欧美性猛交xxxx乱大交退制版 | 日本高清无吗v一区| 亚洲国产欧美在线人成| 欧美一个色资源| 国产美女精品人人做人人爽| 亚洲桃色在线一区| 制服丝袜中文字幕一区| 国产美女视频一区| 亚洲欧美另类综合偷拍| 欧美肥妇毛茸茸| 国产91色综合久久免费分享| 亚洲男人电影天堂| 日韩午夜小视频| 不卡在线观看av| 亚洲第四色夜色| 337p粉嫩大胆色噜噜噜噜亚洲| 97国产一区二区| 麻豆91免费观看| 成人免费一区二区三区在线观看| 五月激情综合色| 久久精品免费观看| 色国产精品一区在线观看| 成人自拍视频在线| eeuss鲁片一区二区三区 | 99视频超级精品| 国产成人午夜精品影院观看视频| 精品一区二区三区的国产在线播放 | 久久99国产精品免费网站| 人人精品人人爱| 欧美va日韩va| 色综合久久久网| 久久精品久久精品| 欧美激情一区二区三区四区| 欧美日韩国产小视频在线观看| 国产成人一级电影| 亚洲午夜日本在线观看| 国产亚洲成年网址在线观看| 欧美丰满少妇xxxxx高潮对白| 99视频热这里只有精品免费| 国产在线日韩欧美| 亚洲女性喷水在线观看一区| 久久久.com| 欧美亚一区二区| 99久久夜色精品国产网站| 蜜乳av一区二区| 亚洲图片有声小说| 亚洲国产精品国自产拍av| 91高清视频在线| 99国产精品视频免费观看| 中文字幕亚洲一区二区av在线| 欧美成人video| 欧美日韩中文字幕精品| 成人国产精品免费| 久久er精品视频| 午夜免费久久看| 亚洲综合免费观看高清完整版| 久久亚洲影视婷婷| 欧美三级视频在线| 99在线视频精品| 国产91精品久久久久久久网曝门| 免费看黄色91| 午夜日韩在线观看| 亚洲精品成人a在线观看| 中文字幕成人av| 久久久午夜电影| 一本一本大道香蕉久在线精品 | 一本久久a久久精品亚洲| 91精品国产综合久久精品| 99国内精品久久| 国产mv日韩mv欧美| 精品一区二区三区久久久| 日本欧美在线看| 日韩理论电影院| 久久蜜桃av一区二区天堂| 精品日本一线二线三线不卡| 欧美亚洲精品一区| 亚洲综合在线五月| 日本韩国一区二区三区视频| 亚洲一区二区美女| 欧美精品一区二区三区视频| 日本不卡高清视频| 日韩欧美第一区| 国产a久久麻豆| 一区在线观看视频| 成人动漫中文字幕| 一区二区理论电影在线观看| 成人污视频在线观看| 亚洲一区二区三区四区不卡| 91久久精品一区二区三区| 石原莉奈在线亚洲三区| 一区二区久久久| 亚洲激情欧美激情| 亚洲一线二线三线视频| 香蕉成人啪国产精品视频综合网| 午夜精彩视频在线观看不卡| 免费一级欧美片在线观看| 蜜桃av一区二区在线观看|