summaryrefslogtreecommitdiff
path: root/xfa/fxfa/cxfa_ffwidget.cpp
diff options
context:
space:
mode:
authorDan Sinclair <dsinclair@chromium.org>2018-01-16 21:20:46 +0000
committerChromium commit bot <commit-bot@chromium.org>2018-01-16 21:20:46 +0000
commit454ab87a354099fb96eee4721328d59f42ca0557 (patch)
treeaa34af648d28465f1558550237cc41b9d9b3696c /xfa/fxfa/cxfa_ffwidget.cpp
parent62d4bb21760706a5d466869db05b504548e7108a (diff)
downloadpdfium-454ab87a354099fb96eee4721328d59f42ca0557.tar.xz
Move StrokePath to the CXFA_Stroke class
This CL moves the code to draw the stroke path to the stroke class. Change-Id: I76ae96e15a166d8bae19618c762d5ad923ed8d8a Reviewed-on: https://pdfium-review.googlesource.com/23030 Reviewed-by: Ryan Harrison <rharrison@chromium.org> Commit-Queue: dsinclair <dsinclair@chromium.org>
Diffstat (limited to 'xfa/fxfa/cxfa_ffwidget.cpp')
-rw-r--r--xfa/fxfa/cxfa_ffwidget.cpp37
1 files changed, 8 insertions, 29 deletions
diff --git a/xfa/fxfa/cxfa_ffwidget.cpp b/xfa/fxfa/cxfa_ffwidget.cpp
index 2642980dd1..8f7bda6d9e 100644
--- a/xfa/fxfa/cxfa_ffwidget.cpp
+++ b/xfa/fxfa/cxfa_ffwidget.cpp
@@ -532,31 +532,6 @@ void XFA_BOX_Fill(CXFA_Box* box,
pGS->RestoreGraphState();
}
-void XFA_BOX_StrokePath(CXFA_Stroke* stroke,
- CXFA_GEPath* pPath,
- CXFA_Graphics* pGS,
- const CFX_Matrix& matrix) {
- if (!stroke || !stroke->IsVisible())
- return;
-
- float fThickness = stroke->GetThickness();
- if (fThickness < 0.001f)
- return;
-
- pGS->SaveGraphState();
- if (stroke->IsCorner() && fThickness > 2 * stroke->GetRadius())
- fThickness = 2 * stroke->GetRadius();
-
- pGS->SetLineWidth(fThickness);
- pGS->EnableActOnDash();
- pGS->SetLineCap(CFX_GraphStateData::LineCapButt);
- XFA_StrokeTypeSetLineDash(pGS, stroke->GetStrokeType(),
- XFA_AttributeEnum::Butt);
- pGS->SetStrokeColor(CXFA_GEColor(stroke->GetColor()));
- pGS->StrokePath(pPath, &matrix);
- pGS->RestoreGraphState();
-}
-
void XFA_BOX_StrokeArc(CXFA_Box* box,
CXFA_Graphics* pGS,
CFX_RectF rtWidget,
@@ -593,7 +568,8 @@ void XFA_BOX_StrokeArc(CXFA_Box* box,
CXFA_GEPath arcPath;
XFA_BOX_GetPath_Arc(box, rtWidget, arcPath, forceRound);
- XFA_BOX_StrokePath(edge, &arcPath, pGS, matrix);
+ if (edge)
+ edge->Stroke(&arcPath, pGS, matrix);
return;
}
pGS->SaveGraphState();
@@ -800,7 +776,8 @@ void XFA_BOX_Stroke_Rect(CXFA_Box* box,
if ((i % 1) == 0 && stroke->GetRadius() < 0) {
bool bEmpty = path.IsEmpty();
if (!bEmpty) {
- XFA_BOX_StrokePath(stroke, &path, pGS, matrix);
+ if (stroke)
+ stroke->Stroke(&path, pGS, matrix);
path.Clear();
}
bStart = true;
@@ -810,7 +787,8 @@ void XFA_BOX_Stroke_Rect(CXFA_Box* box,
bStart = !stroke->SameStyles(strokes[(i + 1) % 8], 0);
if (bStart) {
- XFA_BOX_StrokePath(stroke, &path, pGS, matrix);
+ if (stroke)
+ stroke->Stroke(&path, pGS, matrix);
path.Clear();
}
}
@@ -819,7 +797,8 @@ void XFA_BOX_Stroke_Rect(CXFA_Box* box,
if (bClose) {
path.Close();
}
- XFA_BOX_StrokePath(strokes[7], &path, pGS, matrix);
+ if (strokes[7])
+ strokes[7]->Stroke(&path, pGS, matrix);
}
}