Index: fpdfsdk/src/pdfwindow/PWL_ScrollBar.cpp |
diff --git a/fpdfsdk/src/pdfwindow/PWL_ScrollBar.cpp b/fpdfsdk/src/pdfwindow/PWL_ScrollBar.cpp |
deleted file mode 100644 |
index 03bf3238fab071c8f0f5d45a40958c206339cdb6..0000000000000000000000000000000000000000 |
--- a/fpdfsdk/src/pdfwindow/PWL_ScrollBar.cpp |
+++ /dev/null |
@@ -1,1197 +0,0 @@ |
-// Copyright 2014 PDFium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
- |
-#include "fpdfsdk/include/pdfwindow/PWL_ScrollBar.h" |
-#include "fpdfsdk/include/pdfwindow/PWL_Utils.h" |
-#include "fpdfsdk/include/pdfwindow/PWL_Wnd.h" |
- |
-#define IsFloatZero(f) ((f) < 0.0001 && (f) > -0.0001) |
-#define IsFloatBigger(fa, fb) ((fa) > (fb) && !IsFloatZero((fa) - (fb))) |
-#define IsFloatSmaller(fa, fb) ((fa) < (fb) && !IsFloatZero((fa) - (fb))) |
-#define IsFloatEqual(fa, fb) IsFloatZero((fa) - (fb)) |
- |
-PWL_FLOATRANGE::PWL_FLOATRANGE() { |
- Default(); |
-} |
- |
-PWL_FLOATRANGE::PWL_FLOATRANGE(FX_FLOAT min, FX_FLOAT max) { |
- Set(min, max); |
-} |
- |
-void PWL_FLOATRANGE::Default() { |
- fMin = 0; |
- fMax = 0; |
-} |
- |
-void PWL_FLOATRANGE::Set(FX_FLOAT min, FX_FLOAT max) { |
- if (min > max) { |
- fMin = max; |
- fMax = min; |
- } else { |
- fMin = min; |
- fMax = max; |
- } |
-} |
- |
-FX_BOOL PWL_FLOATRANGE::In(FX_FLOAT x) const { |
- return (IsFloatBigger(x, fMin) || IsFloatEqual(x, fMin)) && |
- (IsFloatSmaller(x, fMax) || IsFloatEqual(x, fMax)); |
-} |
- |
-FX_FLOAT PWL_FLOATRANGE::GetWidth() const { |
- return fMax - fMin; |
-} |
- |
-PWL_SCROLL_PRIVATEDATA::PWL_SCROLL_PRIVATEDATA() { |
- Default(); |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::Default() { |
- ScrollRange.Default(); |
- fScrollPos = ScrollRange.fMin; |
- fClientWidth = 0; |
- fBigStep = 10; |
- fSmallStep = 1; |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::SetScrollRange(FX_FLOAT min, FX_FLOAT max) { |
- ScrollRange.Set(min, max); |
- |
- if (IsFloatSmaller(fScrollPos, ScrollRange.fMin)) |
- fScrollPos = ScrollRange.fMin; |
- if (IsFloatBigger(fScrollPos, ScrollRange.fMax)) |
- fScrollPos = ScrollRange.fMax; |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::SetClientWidth(FX_FLOAT width) { |
- fClientWidth = width; |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::SetSmallStep(FX_FLOAT step) { |
- fSmallStep = step; |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::SetBigStep(FX_FLOAT step) { |
- fBigStep = step; |
-} |
- |
-FX_BOOL PWL_SCROLL_PRIVATEDATA::SetPos(FX_FLOAT pos) { |
- if (ScrollRange.In(pos)) { |
- fScrollPos = pos; |
- return TRUE; |
- } |
- return FALSE; |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::AddSmall() { |
- if (!SetPos(fScrollPos + fSmallStep)) |
- SetPos(ScrollRange.fMax); |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::SubSmall() { |
- if (!SetPos(fScrollPos - fSmallStep)) |
- SetPos(ScrollRange.fMin); |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::AddBig() { |
- if (!SetPos(fScrollPos + fBigStep)) |
- SetPos(ScrollRange.fMax); |
-} |
- |
-void PWL_SCROLL_PRIVATEDATA::SubBig() { |
- if (!SetPos(fScrollPos - fBigStep)) |
- SetPos(ScrollRange.fMin); |
-} |
- |
-CPWL_SBButton::CPWL_SBButton(PWL_SCROLLBAR_TYPE eScrollBarType, |
- PWL_SBBUTTON_TYPE eButtonType) { |
- m_eScrollBarType = eScrollBarType; |
- m_eSBButtonType = eButtonType; |
- |
- m_bMouseDown = FALSE; |
-} |
- |
-CPWL_SBButton::~CPWL_SBButton() {} |
- |
-CFX_ByteString CPWL_SBButton::GetClassName() const { |
- return "CPWL_SBButton"; |
-} |
- |
-void CPWL_SBButton::OnCreate(PWL_CREATEPARAM& cp) { |
- cp.eCursorType = FXCT_ARROW; |
-} |
- |
-void CPWL_SBButton::GetThisAppearanceStream(CFX_ByteTextBuf& sAppStream) { |
- CPWL_Wnd::GetThisAppearanceStream(sAppStream); |
- |
- if (!IsVisible()) |
- return; |
- |
- CFX_ByteTextBuf sButton; |
- |
- CFX_FloatRect rectWnd = GetWindowRect(); |
- |
- if (rectWnd.IsEmpty()) |
- return; |
- |
- sAppStream << "q\n"; |
- |
- CFX_FloatPoint ptCenter = GetCenterPoint(); |
- |
- switch (m_eScrollBarType) { |
- case SBT_HSCROLL: |
- switch (m_eSBButtonType) { |
- case PSBT_MIN: { |
- CFX_FloatPoint pt1(ptCenter.x - PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y); |
- CFX_FloatPoint pt2(ptCenter.x + PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN); |
- CFX_FloatPoint pt3(ptCenter.x + PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN); |
- |
- if (rectWnd.right - rectWnd.left > PWL_TRIANGLE_HALFLEN * 2 && |
- rectWnd.top - rectWnd.bottom > PWL_TRIANGLE_HALFLEN) { |
- sButton << "0 g\n"; |
- sButton << pt1.x << " " << pt1.y << " m\n"; |
- sButton << pt2.x << " " << pt2.y << " l\n"; |
- sButton << pt3.x << " " << pt3.y << " l\n"; |
- sButton << pt1.x << " " << pt1.y << " l f\n"; |
- |
- sAppStream << sButton; |
- } |
- } break; |
- case PSBT_MAX: { |
- CFX_FloatPoint pt1(ptCenter.x + PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y); |
- CFX_FloatPoint pt2(ptCenter.x - PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN); |
- CFX_FloatPoint pt3(ptCenter.x - PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN); |
- |
- if (rectWnd.right - rectWnd.left > PWL_TRIANGLE_HALFLEN * 2 && |
- rectWnd.top - rectWnd.bottom > PWL_TRIANGLE_HALFLEN) { |
- sButton << "0 g\n"; |
- sButton << pt1.x << " " << pt1.y << " m\n"; |
- sButton << pt2.x << " " << pt2.y << " l\n"; |
- sButton << pt3.x << " " << pt3.y << " l\n"; |
- sButton << pt1.x << " " << pt1.y << " l f\n"; |
- |
- sAppStream << sButton; |
- } |
- } break; |
- default: |
- break; |
- } |
- break; |
- case SBT_VSCROLL: |
- switch (m_eSBButtonType) { |
- case PSBT_MIN: { |
- CFX_FloatPoint pt1(ptCenter.x - PWL_TRIANGLE_HALFLEN, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN * 0.5f); |
- CFX_FloatPoint pt2(ptCenter.x + PWL_TRIANGLE_HALFLEN, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN * 0.5f); |
- CFX_FloatPoint pt3(ptCenter.x, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN * 0.5f); |
- |
- if (rectWnd.right - rectWnd.left > PWL_TRIANGLE_HALFLEN * 2 && |
- rectWnd.top - rectWnd.bottom > PWL_TRIANGLE_HALFLEN) { |
- sButton << "0 g\n"; |
- sButton << pt1.x << " " << pt1.y << " m\n"; |
- sButton << pt2.x << " " << pt2.y << " l\n"; |
- sButton << pt3.x << " " << pt3.y << " l\n"; |
- sButton << pt1.x << " " << pt1.y << " l f\n"; |
- |
- sAppStream << sButton; |
- } |
- } break; |
- case PSBT_MAX: { |
- CFX_FloatPoint pt1(ptCenter.x - PWL_TRIANGLE_HALFLEN, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN * 0.5f); |
- CFX_FloatPoint pt2(ptCenter.x + PWL_TRIANGLE_HALFLEN, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN * 0.5f); |
- CFX_FloatPoint pt3(ptCenter.x, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN * 0.5f); |
- |
- if (rectWnd.right - rectWnd.left > PWL_TRIANGLE_HALFLEN * 2 && |
- rectWnd.top - rectWnd.bottom > PWL_TRIANGLE_HALFLEN) { |
- sButton << "0 g\n"; |
- sButton << pt1.x << " " << pt1.y << " m\n"; |
- sButton << pt2.x << " " << pt2.y << " l\n"; |
- sButton << pt3.x << " " << pt3.y << " l\n"; |
- sButton << pt1.x << " " << pt1.y << " l f\n"; |
- |
- sAppStream << sButton; |
- } |
- } break; |
- default: |
- break; |
- } |
- break; |
- default: |
- break; |
- } |
- |
- sAppStream << "Q\n"; |
-} |
- |
-void CPWL_SBButton::DrawThisAppearance(CFX_RenderDevice* pDevice, |
- CFX_Matrix* pUser2Device) { |
- if (!IsVisible()) |
- return; |
- |
- CFX_FloatRect rectWnd = GetWindowRect(); |
- if (rectWnd.IsEmpty()) |
- return; |
- |
- CFX_FloatPoint ptCenter = GetCenterPoint(); |
- int32_t nTransparancy = GetTransparency(); |
- |
- switch (m_eScrollBarType) { |
- case SBT_HSCROLL: |
- CPWL_Wnd::DrawThisAppearance(pDevice, pUser2Device); |
- switch (m_eSBButtonType) { |
- case PSBT_MIN: { |
- CFX_FloatPoint pt1(ptCenter.x - PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y); |
- CFX_FloatPoint pt2(ptCenter.x + PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN); |
- CFX_FloatPoint pt3(ptCenter.x + PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN); |
- |
- if (rectWnd.right - rectWnd.left > PWL_TRIANGLE_HALFLEN * 2 && |
- rectWnd.top - rectWnd.bottom > PWL_TRIANGLE_HALFLEN) { |
- CFX_PathData path; |
- |
- path.SetPointCount(4); |
- path.SetPoint(0, pt1.x, pt1.y, FXPT_MOVETO); |
- path.SetPoint(1, pt2.x, pt2.y, FXPT_LINETO); |
- path.SetPoint(2, pt3.x, pt3.y, FXPT_LINETO); |
- path.SetPoint(3, pt1.x, pt1.y, FXPT_LINETO); |
- |
- pDevice->DrawPath(&path, pUser2Device, NULL, |
- CPWL_Utils::PWLColorToFXColor( |
- PWL_DEFAULT_BLACKCOLOR, nTransparancy), |
- 0, FXFILL_ALTERNATE); |
- } |
- } break; |
- case PSBT_MAX: { |
- CFX_FloatPoint pt1(ptCenter.x + PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y); |
- CFX_FloatPoint pt2(ptCenter.x - PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y + PWL_TRIANGLE_HALFLEN); |
- CFX_FloatPoint pt3(ptCenter.x - PWL_TRIANGLE_HALFLEN * 0.5f, |
- ptCenter.y - PWL_TRIANGLE_HALFLEN); |
- |
- if (rectWnd.right - rectWnd.left > PWL_TRIANGLE_HALFLEN * 2 && |
- rectWnd.top - rectWnd.bottom > PWL_TRIANGLE_HALFLEN) { |
- CFX_PathData path; |
- |
- path.SetPointCount(4); |
- path.SetPoint(0, pt1.x, pt1.y, FXPT_MOVETO); |
- path.SetPoint(1, pt2.x, pt2.y, FXPT_LINETO); |
- path.SetPoint(2, pt3.x, pt3.y, FXPT_LINETO); |
- path.SetPoint(3, pt1.x, pt1.y, FXPT_LINETO); |
- |
- pDevice->DrawPath(&path, pUser2Device, NULL, |
- CPWL_Utils::PWLColorToFXColor( |
- PWL_DEFAULT_BLACKCOLOR, nTransparancy), |
- 0, FXFILL_ALTERNATE); |
- } |
- } break; |
- default: |
- break; |
- } |
- break; |
- case SBT_VSCROLL: |
- switch (m_eSBButtonType) { |
- case PSBT_MIN: { |
- // draw border |
- CFX_FloatRect rcDraw = rectWnd; |
- CPWL_Utils::DrawStrokeRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(nTransparancy, 100, 100, 100), |
- 0.0f); |
- |
- // draw inner border |
- rcDraw = CPWL_Utils::DeflateRect(rectWnd, 0.5f); |
- CPWL_Utils::DrawStrokeRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(nTransparancy, 255, 255, 255), |
- 1.0f); |
- |
- // draw background |
- |
- rcDraw = CPWL_Utils::DeflateRect(rectWnd, 1.0f); |
- |
- if (IsEnabled()) |
- CPWL_Utils::DrawShadow(pDevice, pUser2Device, TRUE, FALSE, rcDraw, |
- nTransparancy, 80, 220); |
- else |
- CPWL_Utils::DrawFillRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(255, 255, 255, 255)); |
- |
- // draw arrow |
- |
- if (rectWnd.top - rectWnd.bottom > 6.0f) { |
- FX_FLOAT fX = rectWnd.left + 1.5f; |
- FX_FLOAT fY = rectWnd.bottom; |
- CFX_FloatPoint pts[7] = {CFX_FloatPoint(fX + 2.5f, fY + 4.0f), |
- CFX_FloatPoint(fX + 2.5f, fY + 3.0f), |
- CFX_FloatPoint(fX + 4.5f, fY + 5.0f), |
- CFX_FloatPoint(fX + 6.5f, fY + 3.0f), |
- CFX_FloatPoint(fX + 6.5f, fY + 4.0f), |
- CFX_FloatPoint(fX + 4.5f, fY + 6.0f), |
- CFX_FloatPoint(fX + 2.5f, fY + 4.0f)}; |
- |
- if (IsEnabled()) |
- CPWL_Utils::DrawFillArea( |
- pDevice, pUser2Device, pts, 7, |
- ArgbEncode(nTransparancy, 255, 255, 255)); |
- else |
- CPWL_Utils::DrawFillArea(pDevice, pUser2Device, pts, 7, |
- CPWL_Utils::PWLColorToFXColor( |
- PWL_DEFAULT_HEAVYGRAYCOLOR, 255)); |
- } |
- } break; |
- case PSBT_MAX: { |
- // draw border |
- CFX_FloatRect rcDraw = rectWnd; |
- CPWL_Utils::DrawStrokeRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(nTransparancy, 100, 100, 100), |
- 0.0f); |
- |
- // draw inner border |
- rcDraw = CPWL_Utils::DeflateRect(rectWnd, 0.5f); |
- CPWL_Utils::DrawStrokeRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(nTransparancy, 255, 255, 255), |
- 1.0f); |
- |
- // draw background |
- rcDraw = CPWL_Utils::DeflateRect(rectWnd, 1.0f); |
- if (IsEnabled()) |
- CPWL_Utils::DrawShadow(pDevice, pUser2Device, TRUE, FALSE, rcDraw, |
- nTransparancy, 80, 220); |
- else |
- CPWL_Utils::DrawFillRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(255, 255, 255, 255)); |
- |
- // draw arrow |
- |
- if (rectWnd.top - rectWnd.bottom > 6.0f) { |
- FX_FLOAT fX = rectWnd.left + 1.5f; |
- FX_FLOAT fY = rectWnd.bottom; |
- |
- CFX_FloatPoint pts[7] = {CFX_FloatPoint(fX + 2.5f, fY + 5.0f), |
- CFX_FloatPoint(fX + 2.5f, fY + 6.0f), |
- CFX_FloatPoint(fX + 4.5f, fY + 4.0f), |
- CFX_FloatPoint(fX + 6.5f, fY + 6.0f), |
- CFX_FloatPoint(fX + 6.5f, fY + 5.0f), |
- CFX_FloatPoint(fX + 4.5f, fY + 3.0f), |
- CFX_FloatPoint(fX + 2.5f, fY + 5.0f)}; |
- |
- if (IsEnabled()) |
- CPWL_Utils::DrawFillArea( |
- pDevice, pUser2Device, pts, 7, |
- ArgbEncode(nTransparancy, 255, 255, 255)); |
- else |
- CPWL_Utils::DrawFillArea(pDevice, pUser2Device, pts, 7, |
- CPWL_Utils::PWLColorToFXColor( |
- PWL_DEFAULT_HEAVYGRAYCOLOR, 255)); |
- } |
- } break; |
- case PSBT_POS: { |
- // draw border |
- CFX_FloatRect rcDraw = rectWnd; |
- CPWL_Utils::DrawStrokeRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(nTransparancy, 100, 100, 100), |
- 0.0f); |
- |
- // draw inner border |
- rcDraw = CPWL_Utils::DeflateRect(rectWnd, 0.5f); |
- CPWL_Utils::DrawStrokeRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(nTransparancy, 255, 255, 255), |
- 1.0f); |
- |
- if (IsEnabled()) { |
- // draw shadow effect |
- |
- CFX_FloatPoint ptTop = |
- CFX_FloatPoint(rectWnd.left, rectWnd.top - 1.0f); |
- CFX_FloatPoint ptBottom = |
- CFX_FloatPoint(rectWnd.left, rectWnd.bottom + 1.0f); |
- |
- ptTop.x += 1.5f; |
- ptBottom.x += 1.5f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 210, 210, 210), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 220, 220, 220), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 240, 240, 240), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 240, 240, 240), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 210, 210, 210), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 180, 180, 180), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 150, 150, 150), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 150, 150, 150), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 180, 180, 180), |
- 1.0f); |
- |
- ptTop.x += 1.0f; |
- ptBottom.x += 1.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptTop, ptBottom, |
- ArgbEncode(nTransparancy, 210, 210, 210), |
- 1.0f); |
- } else { |
- CPWL_Utils::DrawFillRect(pDevice, pUser2Device, rcDraw, |
- ArgbEncode(255, 255, 255, 255)); |
- } |
- |
- // draw friction |
- |
- if (rectWnd.Height() > 8.0f) { |
- FX_COLORREF crStroke = ArgbEncode(nTransparancy, 120, 120, 120); |
- if (!IsEnabled()) |
- crStroke = CPWL_Utils::PWLColorToFXColor( |
- PWL_DEFAULT_HEAVYGRAYCOLOR, 255); |
- |
- FX_FLOAT nFrictionWidth = 5.0f; |
- FX_FLOAT nFrictionHeight = 5.5f; |
- |
- CFX_FloatPoint ptLeft = |
- CFX_FloatPoint(ptCenter.x - nFrictionWidth / 2.0f, |
- ptCenter.y - nFrictionHeight / 2.0f + 0.5f); |
- CFX_FloatPoint ptRight = |
- CFX_FloatPoint(ptCenter.x + nFrictionWidth / 2.0f, |
- ptCenter.y - nFrictionHeight / 2.0f + 0.5f); |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptLeft, ptRight, |
- crStroke, 1.0f); |
- |
- ptLeft.y += 2.0f; |
- ptRight.y += 2.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptLeft, ptRight, |
- crStroke, 1.0f); |
- |
- ptLeft.y += 2.0f; |
- ptRight.y += 2.0f; |
- |
- CPWL_Utils::DrawStrokeLine(pDevice, pUser2Device, ptLeft, ptRight, |
- crStroke, 1.0f); |
- } |
- } break; |
- default: |
- break; |
- } |
- break; |
- default: |
- break; |
- } |
-} |
- |
-FX_BOOL CPWL_SBButton::OnLButtonDown(const CFX_FloatPoint& point, |
- FX_DWORD nFlag) { |
- CPWL_Wnd::OnLButtonDown(point, nFlag); |
- |
- if (CPWL_Wnd* pParent = GetParentWindow()) |
- pParent->OnNotify(this, PNM_LBUTTONDOWN, 0, (intptr_t)&point); |
- |
- m_bMouseDown = TRUE; |
- SetCapture(); |
- |
- return TRUE; |
-} |
- |
-FX_BOOL CPWL_SBButton::OnLButtonUp(const CFX_FloatPoint& point, |
- FX_DWORD nFlag) { |
- CPWL_Wnd::OnLButtonUp(point, nFlag); |
- |
- if (CPWL_Wnd* pParent = GetParentWindow()) |
- pParent->OnNotify(this, PNM_LBUTTONUP, 0, (intptr_t)&point); |
- |
- m_bMouseDown = FALSE; |
- ReleaseCapture(); |
- |
- return TRUE; |
-} |
- |
-FX_BOOL CPWL_SBButton::OnMouseMove(const CFX_FloatPoint& point, |
- FX_DWORD nFlag) { |
- CPWL_Wnd::OnMouseMove(point, nFlag); |
- |
- if (CPWL_Wnd* pParent = GetParentWindow()) { |
- pParent->OnNotify(this, PNM_MOUSEMOVE, 0, (intptr_t)&point); |
- } |
- |
- return TRUE; |
-} |
- |
-CPWL_ScrollBar::CPWL_ScrollBar(PWL_SCROLLBAR_TYPE sbType) |
- : m_sbType(sbType), |
- m_pMinButton(NULL), |
- m_pMaxButton(NULL), |
- m_pPosButton(NULL), |
- m_bMouseDown(FALSE), |
- m_bMinOrMax(FALSE), |
- m_bNotifyForever(TRUE) {} |
- |
-CPWL_ScrollBar::~CPWL_ScrollBar() {} |
- |
-CFX_ByteString CPWL_ScrollBar::GetClassName() const { |
- return "CPWL_ScrollBar"; |
-} |
- |
-void CPWL_ScrollBar::OnCreate(PWL_CREATEPARAM& cp) { |
- cp.eCursorType = FXCT_ARROW; |
-} |
- |
-void CPWL_ScrollBar::RePosChildWnd() { |
- CFX_FloatRect rcClient = GetClientRect(); |
- CFX_FloatRect rcMinButton, rcMaxButton; |
- FX_FLOAT fBWidth = 0; |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- if (rcClient.right - rcClient.left > |
- PWL_SCROLLBAR_BUTTON_WIDTH * 2 + PWL_SCROLLBAR_POSBUTTON_MINWIDTH + |
- 2) { |
- rcMinButton = CFX_FloatRect(rcClient.left, rcClient.bottom, |
- rcClient.left + PWL_SCROLLBAR_BUTTON_WIDTH, |
- rcClient.top); |
- rcMaxButton = |
- CFX_FloatRect(rcClient.right - PWL_SCROLLBAR_BUTTON_WIDTH, |
- rcClient.bottom, rcClient.right, rcClient.top); |
- } else { |
- fBWidth = (rcClient.right - rcClient.left - |
- PWL_SCROLLBAR_POSBUTTON_MINWIDTH - 2) / |
- 2; |
- |
- if (fBWidth > 0) { |
- rcMinButton = CFX_FloatRect(rcClient.left, rcClient.bottom, |
- rcClient.left + fBWidth, rcClient.top); |
- rcMaxButton = CFX_FloatRect(rcClient.right - fBWidth, rcClient.bottom, |
- rcClient.right, rcClient.top); |
- } else { |
- SetVisible(FALSE); |
- } |
- } |
- break; |
- case SBT_VSCROLL: |
- if (IsFloatBigger(rcClient.top - rcClient.bottom, |
- PWL_SCROLLBAR_BUTTON_WIDTH * 2 + |
- PWL_SCROLLBAR_POSBUTTON_MINWIDTH + 2)) { |
- rcMinButton = CFX_FloatRect(rcClient.left, |
- rcClient.top - PWL_SCROLLBAR_BUTTON_WIDTH, |
- rcClient.right, rcClient.top); |
- rcMaxButton = |
- CFX_FloatRect(rcClient.left, rcClient.bottom, rcClient.right, |
- rcClient.bottom + PWL_SCROLLBAR_BUTTON_WIDTH); |
- } else { |
- fBWidth = (rcClient.top - rcClient.bottom - |
- PWL_SCROLLBAR_POSBUTTON_MINWIDTH - 2) / |
- 2; |
- |
- if (IsFloatBigger(fBWidth, 0)) { |
- rcMinButton = CFX_FloatRect(rcClient.left, rcClient.top - fBWidth, |
- rcClient.right, rcClient.top); |
- rcMaxButton = |
- CFX_FloatRect(rcClient.left, rcClient.bottom, rcClient.right, |
- rcClient.bottom + fBWidth); |
- } else { |
- SetVisible(FALSE); |
- } |
- } |
- break; |
- } |
- |
- if (m_pMinButton) |
- m_pMinButton->Move(rcMinButton, TRUE, FALSE); |
- if (m_pMaxButton) |
- m_pMaxButton->Move(rcMaxButton, TRUE, FALSE); |
- MovePosButton(FALSE); |
-} |
- |
-void CPWL_ScrollBar::GetThisAppearanceStream(CFX_ByteTextBuf& sAppStream) { |
- CFX_FloatRect rectWnd = GetWindowRect(); |
- |
- if (IsVisible() && !rectWnd.IsEmpty()) { |
- CFX_ByteTextBuf sButton; |
- |
- sButton << "q\n"; |
- sButton << "0 w\n" |
- << CPWL_Utils::GetColorAppStream(GetBackgroundColor(), TRUE); |
- sButton << rectWnd.left << " " << rectWnd.bottom << " " |
- << rectWnd.right - rectWnd.left << " " |
- << rectWnd.top - rectWnd.bottom << " re b Q\n"; |
- |
- sAppStream << sButton; |
- } |
-} |
- |
-void CPWL_ScrollBar::DrawThisAppearance(CFX_RenderDevice* pDevice, |
- CFX_Matrix* pUser2Device) { |
- CFX_FloatRect rectWnd = GetWindowRect(); |
- |
- if (IsVisible() && !rectWnd.IsEmpty()) { |
- CPWL_Utils::DrawFillRect(pDevice, pUser2Device, rectWnd, |
- GetBackgroundColor(), GetTransparency()); |
- |
- CPWL_Utils::DrawStrokeLine( |
- pDevice, pUser2Device, |
- CFX_FloatPoint(rectWnd.left + 2.0f, rectWnd.top - 2.0f), |
- CFX_FloatPoint(rectWnd.left + 2.0f, rectWnd.bottom + 2.0f), |
- ArgbEncode(GetTransparency(), 100, 100, 100), 1.0f); |
- |
- CPWL_Utils::DrawStrokeLine( |
- pDevice, pUser2Device, |
- CFX_FloatPoint(rectWnd.right - 2.0f, rectWnd.top - 2.0f), |
- CFX_FloatPoint(rectWnd.right - 2.0f, rectWnd.bottom + 2.0f), |
- ArgbEncode(GetTransparency(), 100, 100, 100), 1.0f); |
- } |
-} |
- |
-FX_BOOL CPWL_ScrollBar::OnLButtonDown(const CFX_FloatPoint& point, |
- FX_DWORD nFlag) { |
- CPWL_Wnd::OnLButtonDown(point, nFlag); |
- |
- if (HasFlag(PWS_AUTOTRANSPARENT)) { |
- if (GetTransparency() != 255) { |
- SetTransparency(255); |
- InvalidateRect(); |
- } |
- } |
- |
- CFX_FloatRect rcMinArea, rcMaxArea; |
- |
- if (m_pPosButton && m_pPosButton->IsVisible()) { |
- CFX_FloatRect rcClient = GetClientRect(); |
- CFX_FloatRect rcPosButton = m_pPosButton->GetWindowRect(); |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- rcMinArea = |
- CFX_FloatRect(rcClient.left + PWL_SCROLLBAR_BUTTON_WIDTH, |
- rcClient.bottom, rcPosButton.left, rcClient.top); |
- rcMaxArea = CFX_FloatRect(rcPosButton.right, rcClient.bottom, |
- rcClient.right - PWL_SCROLLBAR_BUTTON_WIDTH, |
- rcClient.top); |
- |
- break; |
- case SBT_VSCROLL: |
- rcMinArea = |
- CFX_FloatRect(rcClient.left, rcPosButton.top, rcClient.right, |
- rcClient.top - PWL_SCROLLBAR_BUTTON_WIDTH); |
- rcMaxArea = CFX_FloatRect(rcClient.left, |
- rcClient.bottom + PWL_SCROLLBAR_BUTTON_WIDTH, |
- rcClient.right, rcPosButton.bottom); |
- break; |
- } |
- |
- rcMinArea.Normalize(); |
- rcMaxArea.Normalize(); |
- |
- if (rcMinArea.Contains(point.x, point.y)) { |
- m_sData.SubBig(); |
- MovePosButton(TRUE); |
- NotifyScrollWindow(); |
- } |
- |
- if (rcMaxArea.Contains(point.x, point.y)) { |
- m_sData.AddBig(); |
- MovePosButton(TRUE); |
- NotifyScrollWindow(); |
- } |
- } |
- |
- return TRUE; |
-} |
- |
-FX_BOOL CPWL_ScrollBar::OnLButtonUp(const CFX_FloatPoint& point, |
- FX_DWORD nFlag) { |
- CPWL_Wnd::OnLButtonUp(point, nFlag); |
- |
- if (HasFlag(PWS_AUTOTRANSPARENT)) { |
- if (GetTransparency() != PWL_SCROLLBAR_TRANSPARANCY) { |
- SetTransparency(PWL_SCROLLBAR_TRANSPARANCY); |
- InvalidateRect(); |
- } |
- } |
- |
- EndTimer(); |
- m_bMouseDown = FALSE; |
- |
- return TRUE; |
-} |
- |
-void CPWL_ScrollBar::OnNotify(CPWL_Wnd* pWnd, |
- FX_DWORD msg, |
- intptr_t wParam, |
- intptr_t lParam) { |
- CPWL_Wnd::OnNotify(pWnd, msg, wParam, lParam); |
- |
- switch (msg) { |
- case PNM_LBUTTONDOWN: |
- if (pWnd == m_pMinButton) { |
- OnMinButtonLBDown(*(CFX_FloatPoint*)lParam); |
- } |
- |
- if (pWnd == m_pMaxButton) { |
- OnMaxButtonLBDown(*(CFX_FloatPoint*)lParam); |
- } |
- |
- if (pWnd == m_pPosButton) { |
- OnPosButtonLBDown(*(CFX_FloatPoint*)lParam); |
- } |
- break; |
- case PNM_LBUTTONUP: |
- if (pWnd == m_pMinButton) { |
- OnMinButtonLBUp(*(CFX_FloatPoint*)lParam); |
- } |
- |
- if (pWnd == m_pMaxButton) { |
- OnMaxButtonLBUp(*(CFX_FloatPoint*)lParam); |
- } |
- |
- if (pWnd == m_pPosButton) { |
- OnPosButtonLBUp(*(CFX_FloatPoint*)lParam); |
- } |
- break; |
- case PNM_MOUSEMOVE: |
- if (pWnd == m_pMinButton) { |
- OnMinButtonMouseMove(*(CFX_FloatPoint*)lParam); |
- } |
- |
- if (pWnd == m_pMaxButton) { |
- OnMaxButtonMouseMove(*(CFX_FloatPoint*)lParam); |
- } |
- |
- if (pWnd == m_pPosButton) { |
- OnPosButtonMouseMove(*(CFX_FloatPoint*)lParam); |
- } |
- break; |
- case PNM_SETSCROLLINFO: { |
- if (PWL_SCROLL_INFO* pInfo = (PWL_SCROLL_INFO*)lParam) { |
- if (FXSYS_memcmp(&m_OriginInfo, pInfo, sizeof(PWL_SCROLL_INFO)) != 0) { |
- m_OriginInfo = *pInfo; |
- FX_FLOAT fMax = |
- pInfo->fContentMax - pInfo->fContentMin - pInfo->fPlateWidth; |
- fMax = fMax > 0.0f ? fMax : 0.0f; |
- SetScrollRange(0, fMax, pInfo->fPlateWidth); |
- SetScrollStep(pInfo->fBigStep, pInfo->fSmallStep); |
- } |
- } |
- } break; |
- case PNM_SETSCROLLPOS: { |
- FX_FLOAT fPos = *(FX_FLOAT*)lParam; |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- fPos = fPos - m_OriginInfo.fContentMin; |
- break; |
- case SBT_VSCROLL: |
- fPos = m_OriginInfo.fContentMax - fPos; |
- break; |
- } |
- SetScrollPos(fPos); |
- } break; |
- } |
-} |
- |
-void CPWL_ScrollBar::CreateButtons(const PWL_CREATEPARAM& cp) { |
- PWL_CREATEPARAM scp = cp; |
- scp.pParentWnd = this; |
- scp.dwBorderWidth = 2; |
- scp.nBorderStyle = PBS_BEVELED; |
- |
- scp.dwFlags = |
- PWS_VISIBLE | PWS_CHILD | PWS_BORDER | PWS_BACKGROUND | PWS_NOREFRESHCLIP; |
- |
- if (!m_pMinButton) { |
- m_pMinButton = new CPWL_SBButton(m_sbType, PSBT_MIN); |
- m_pMinButton->Create(scp); |
- } |
- |
- if (!m_pMaxButton) { |
- m_pMaxButton = new CPWL_SBButton(m_sbType, PSBT_MAX); |
- m_pMaxButton->Create(scp); |
- } |
- |
- if (!m_pPosButton) { |
- m_pPosButton = new CPWL_SBButton(m_sbType, PSBT_POS); |
- m_pPosButton->SetVisible(FALSE); |
- m_pPosButton->Create(scp); |
- } |
-} |
- |
-FX_FLOAT CPWL_ScrollBar::GetScrollBarWidth() const { |
- if (!IsVisible()) |
- return 0; |
- |
- return PWL_SCROLLBAR_WIDTH; |
-} |
- |
-void CPWL_ScrollBar::SetScrollRange(FX_FLOAT fMin, |
- FX_FLOAT fMax, |
- FX_FLOAT fClientWidth) { |
- if (m_pPosButton) { |
- m_sData.SetScrollRange(fMin, fMax); |
- m_sData.SetClientWidth(fClientWidth); |
- |
- if (IsFloatSmaller(m_sData.ScrollRange.GetWidth(), 0.0f)) { |
- m_pPosButton->SetVisible(FALSE); |
- } else { |
- m_pPosButton->SetVisible(TRUE); |
- MovePosButton(TRUE); |
- } |
- } |
-} |
- |
-void CPWL_ScrollBar::SetScrollPos(FX_FLOAT fPos) { |
- FX_FLOAT fOldPos = m_sData.fScrollPos; |
- |
- m_sData.SetPos(fPos); |
- |
- if (!IsFloatEqual(m_sData.fScrollPos, fOldPos)) |
- MovePosButton(TRUE); |
-} |
- |
-void CPWL_ScrollBar::SetScrollStep(FX_FLOAT fBigStep, FX_FLOAT fSmallStep) { |
- m_sData.SetBigStep(fBigStep); |
- m_sData.SetSmallStep(fSmallStep); |
-} |
- |
-void CPWL_ScrollBar::MovePosButton(FX_BOOL bRefresh) { |
- ASSERT(m_pMinButton); |
- ASSERT(m_pMaxButton); |
- |
- if (m_pPosButton->IsVisible()) { |
- CFX_FloatRect rcClient; |
- CFX_FloatRect rcPosArea, rcPosButton; |
- |
- rcClient = GetClientRect(); |
- rcPosArea = GetScrollArea(); |
- |
- FX_FLOAT fLeft, fRight, fTop, fBottom; |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- fLeft = TrueToFace(m_sData.fScrollPos); |
- fRight = TrueToFace(m_sData.fScrollPos + m_sData.fClientWidth); |
- |
- if (fRight - fLeft < PWL_SCROLLBAR_POSBUTTON_MINWIDTH) |
- fRight = fLeft + PWL_SCROLLBAR_POSBUTTON_MINWIDTH; |
- |
- if (fRight > rcPosArea.right) { |
- fRight = rcPosArea.right; |
- fLeft = fRight - PWL_SCROLLBAR_POSBUTTON_MINWIDTH; |
- } |
- |
- rcPosButton = |
- CFX_FloatRect(fLeft, rcPosArea.bottom, fRight, rcPosArea.top); |
- |
- break; |
- case SBT_VSCROLL: |
- fBottom = TrueToFace(m_sData.fScrollPos + m_sData.fClientWidth); |
- fTop = TrueToFace(m_sData.fScrollPos); |
- |
- if (IsFloatSmaller(fTop - fBottom, PWL_SCROLLBAR_POSBUTTON_MINWIDTH)) |
- fBottom = fTop - PWL_SCROLLBAR_POSBUTTON_MINWIDTH; |
- |
- if (IsFloatSmaller(fBottom, rcPosArea.bottom)) { |
- fBottom = rcPosArea.bottom; |
- fTop = fBottom + PWL_SCROLLBAR_POSBUTTON_MINWIDTH; |
- } |
- |
- rcPosButton = |
- CFX_FloatRect(rcPosArea.left, fBottom, rcPosArea.right, fTop); |
- |
- break; |
- } |
- |
- m_pPosButton->Move(rcPosButton, TRUE, bRefresh); |
- } |
-} |
- |
-void CPWL_ScrollBar::OnMinButtonLBDown(const CFX_FloatPoint& point) { |
- m_sData.SubSmall(); |
- MovePosButton(TRUE); |
- NotifyScrollWindow(); |
- |
- m_bMinOrMax = TRUE; |
- |
- EndTimer(); |
- BeginTimer(100); |
-} |
- |
-void CPWL_ScrollBar::OnMinButtonLBUp(const CFX_FloatPoint& point) {} |
- |
-void CPWL_ScrollBar::OnMinButtonMouseMove(const CFX_FloatPoint& point) {} |
- |
-void CPWL_ScrollBar::OnMaxButtonLBDown(const CFX_FloatPoint& point) { |
- m_sData.AddSmall(); |
- MovePosButton(TRUE); |
- NotifyScrollWindow(); |
- |
- m_bMinOrMax = FALSE; |
- |
- EndTimer(); |
- BeginTimer(100); |
-} |
- |
-void CPWL_ScrollBar::OnMaxButtonLBUp(const CFX_FloatPoint& point) {} |
- |
-void CPWL_ScrollBar::OnMaxButtonMouseMove(const CFX_FloatPoint& point) {} |
- |
-void CPWL_ScrollBar::OnPosButtonLBDown(const CFX_FloatPoint& point) { |
- m_bMouseDown = TRUE; |
- |
- if (m_pPosButton) { |
- CFX_FloatRect rcPosButton = m_pPosButton->GetWindowRect(); |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- m_nOldPos = point.x; |
- m_fOldPosButton = rcPosButton.left; |
- break; |
- case SBT_VSCROLL: |
- m_nOldPos = point.y; |
- m_fOldPosButton = rcPosButton.top; |
- break; |
- } |
- } |
-} |
- |
-void CPWL_ScrollBar::OnPosButtonLBUp(const CFX_FloatPoint& point) { |
- if (m_bMouseDown) { |
- if (!m_bNotifyForever) |
- NotifyScrollWindow(); |
- } |
- m_bMouseDown = FALSE; |
-} |
- |
-void CPWL_ScrollBar::OnPosButtonMouseMove(const CFX_FloatPoint& point) { |
- FX_FLOAT fOldScrollPos = m_sData.fScrollPos; |
- |
- FX_FLOAT fNewPos = 0; |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- if (FXSYS_fabs(point.x - m_nOldPos) < 1) |
- return; |
- fNewPos = FaceToTrue(m_fOldPosButton + point.x - m_nOldPos); |
- break; |
- case SBT_VSCROLL: |
- if (FXSYS_fabs(point.y - m_nOldPos) < 1) |
- return; |
- fNewPos = FaceToTrue(m_fOldPosButton + point.y - m_nOldPos); |
- break; |
- } |
- |
- if (m_bMouseDown) { |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- |
- if (IsFloatSmaller(fNewPos, m_sData.ScrollRange.fMin)) { |
- fNewPos = m_sData.ScrollRange.fMin; |
- } |
- |
- if (IsFloatBigger(fNewPos, m_sData.ScrollRange.fMax)) { |
- fNewPos = m_sData.ScrollRange.fMax; |
- } |
- |
- m_sData.SetPos(fNewPos); |
- |
- break; |
- case SBT_VSCROLL: |
- |
- if (IsFloatSmaller(fNewPos, m_sData.ScrollRange.fMin)) { |
- fNewPos = m_sData.ScrollRange.fMin; |
- } |
- |
- if (IsFloatBigger(fNewPos, m_sData.ScrollRange.fMax)) { |
- fNewPos = m_sData.ScrollRange.fMax; |
- } |
- |
- m_sData.SetPos(fNewPos); |
- |
- break; |
- } |
- |
- if (!IsFloatEqual(fOldScrollPos, m_sData.fScrollPos)) { |
- MovePosButton(TRUE); |
- |
- if (m_bNotifyForever) |
- NotifyScrollWindow(); |
- } |
- } |
-} |
- |
-void CPWL_ScrollBar::NotifyScrollWindow() { |
- if (CPWL_Wnd* pParent = GetParentWindow()) { |
- FX_FLOAT fPos; |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- fPos = m_OriginInfo.fContentMin + m_sData.fScrollPos; |
- break; |
- case SBT_VSCROLL: |
- fPos = m_OriginInfo.fContentMax - m_sData.fScrollPos; |
- break; |
- } |
- pParent->OnNotify(this, PNM_SCROLLWINDOW, (intptr_t)m_sbType, |
- (intptr_t)&fPos); |
- } |
-} |
- |
-CFX_FloatRect CPWL_ScrollBar::GetScrollArea() const { |
- CFX_FloatRect rcClient = GetClientRect(); |
- CFX_FloatRect rcArea; |
- |
- if (!m_pMinButton || !m_pMaxButton) |
- return rcClient; |
- |
- CFX_FloatRect rcMin = m_pMinButton->GetWindowRect(); |
- CFX_FloatRect rcMax = m_pMaxButton->GetWindowRect(); |
- |
- FX_FLOAT fMinWidth = rcMin.right - rcMin.left; |
- FX_FLOAT fMinHeight = rcMin.top - rcMin.bottom; |
- FX_FLOAT fMaxWidth = rcMax.right - rcMax.left; |
- FX_FLOAT fMaxHeight = rcMax.top - rcMax.bottom; |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- if (rcClient.right - rcClient.left > fMinWidth + fMaxWidth + 2) { |
- rcArea = CFX_FloatRect(rcClient.left + fMinWidth + 1, rcClient.bottom, |
- rcClient.right - fMaxWidth - 1, rcClient.top); |
- } else { |
- rcArea = CFX_FloatRect(rcClient.left + fMinWidth + 1, rcClient.bottom, |
- rcClient.left + fMinWidth + 1, rcClient.top); |
- } |
- break; |
- case SBT_VSCROLL: |
- if (rcClient.top - rcClient.bottom > fMinHeight + fMaxHeight + 2) { |
- rcArea = CFX_FloatRect(rcClient.left, rcClient.bottom + fMinHeight + 1, |
- rcClient.right, rcClient.top - fMaxHeight - 1); |
- } else { |
- rcArea = |
- CFX_FloatRect(rcClient.left, rcClient.bottom + fMinHeight + 1, |
- rcClient.right, rcClient.bottom + fMinHeight + 1); |
- } |
- break; |
- } |
- |
- rcArea.Normalize(); |
- |
- return rcArea; |
-} |
- |
-FX_FLOAT CPWL_ScrollBar::TrueToFace(FX_FLOAT fTrue) { |
- CFX_FloatRect rcPosArea; |
- rcPosArea = GetScrollArea(); |
- |
- FX_FLOAT fFactWidth = m_sData.ScrollRange.GetWidth() + m_sData.fClientWidth; |
- fFactWidth = fFactWidth == 0 ? 1 : fFactWidth; |
- |
- FX_FLOAT fFace = 0; |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- fFace = rcPosArea.left + |
- fTrue * (rcPosArea.right - rcPosArea.left) / fFactWidth; |
- break; |
- case SBT_VSCROLL: |
- fFace = rcPosArea.top - |
- fTrue * (rcPosArea.top - rcPosArea.bottom) / fFactWidth; |
- break; |
- } |
- |
- return fFace; |
-} |
- |
-FX_FLOAT CPWL_ScrollBar::FaceToTrue(FX_FLOAT fFace) { |
- CFX_FloatRect rcPosArea; |
- rcPosArea = GetScrollArea(); |
- |
- FX_FLOAT fFactWidth = m_sData.ScrollRange.GetWidth() + m_sData.fClientWidth; |
- fFactWidth = fFactWidth == 0 ? 1 : fFactWidth; |
- |
- FX_FLOAT fTrue = 0; |
- |
- switch (m_sbType) { |
- case SBT_HSCROLL: |
- fTrue = (fFace - rcPosArea.left) * fFactWidth / |
- (rcPosArea.right - rcPosArea.left); |
- break; |
- case SBT_VSCROLL: |
- fTrue = (rcPosArea.top - fFace) * fFactWidth / |
- (rcPosArea.top - rcPosArea.bottom); |
- break; |
- } |
- |
- return fTrue; |
-} |
- |
-void CPWL_ScrollBar::CreateChildWnd(const PWL_CREATEPARAM& cp) { |
- CreateButtons(cp); |
-} |
- |
-void CPWL_ScrollBar::TimerProc() { |
- PWL_SCROLL_PRIVATEDATA sTemp = m_sData; |
- |
- if (m_bMinOrMax) |
- m_sData.SubSmall(); |
- else |
- m_sData.AddSmall(); |
- |
- if (FXSYS_memcmp(&m_sData, &sTemp, sizeof(PWL_SCROLL_PRIVATEDATA)) != 0) { |
- MovePosButton(TRUE); |
- NotifyScrollWindow(); |
- } |
-} |