Teach FPDFPageObj_SetMatrix() to set the matrix for form objects.
Convert some embedder tests to use the new API capability, instead of
accessing the internal CPDF_FormObject directly.
Change-Id: If5384dca03f9a11304b923afd7a36c4311490fc8
Reviewed-on: https://pdfium-review.googlesource.com/c/pdfium/+/82613
Commit-Queue: Lei Zhang <thestig@chromium.org>
Reviewed-by: Tom Sepez <tsepez@chromium.org>
diff --git a/fpdfsdk/fpdf_edit_embeddertest.cpp b/fpdfsdk/fpdf_edit_embeddertest.cpp
index 999e8e9..11fca24 100644
--- a/fpdfsdk/fpdf_edit_embeddertest.cpp
+++ b/fpdfsdk/fpdf_edit_embeddertest.cpp
@@ -2487,13 +2487,9 @@
ASSERT_EQ(nullptr, FPDFFormObj_GetObject(form, -1));
ASSERT_EQ(nullptr, FPDFFormObj_GetObject(form, 2));
- // Reset the form object matrix to identity.
- CPDF_FormObject* pFormObj = CPDFPageObjectFromFPDFPageObject(form)->AsForm();
- pFormObj->Transform(pFormObj->form_matrix().GetInverse());
-
// FPDFPageObj_GetMatrix() positive testing for forms.
static constexpr FS_MATRIX kMatrix = {1.0f, 1.5f, 2.0f, 2.5f, 100.0f, 200.0f};
- pFormObj->Transform(CFXMatrixFromFSMatrix(kMatrix));
+ EXPECT_TRUE(FPDFPageObj_SetMatrix(form, &kMatrix));
FS_MATRIX matrix;
EXPECT_TRUE(FPDFPageObj_GetMatrix(form, &matrix));
diff --git a/fpdfsdk/fpdf_editpage.cpp b/fpdfsdk/fpdf_editpage.cpp
index e118a91a..dc0f8a2 100644
--- a/fpdfsdk/fpdf_editpage.cpp
+++ b/fpdfsdk/fpdf_editpage.cpp
@@ -662,7 +662,8 @@
case CPDF_PageObject::SHADING:
return false;
case CPDF_PageObject::FORM:
- return false;
+ pPageObj->AsForm()->SetFormMatrix(cmatrix);
+ break;
default:
NOTREACHED();
return false;
diff --git a/fpdfsdk/fpdf_ppo_embeddertest.cpp b/fpdfsdk/fpdf_ppo_embeddertest.cpp
index dc5130c..f635996 100644
--- a/fpdfsdk/fpdf_ppo_embeddertest.cpp
+++ b/fpdfsdk/fpdf_ppo_embeddertest.cpp
@@ -249,13 +249,8 @@
ASSERT_TRUE(page_object);
ASSERT_EQ(FPDF_PAGEOBJ_FORM, FPDFPageObj_GetType(page_object));
- // Access the CPDF_FormObject underneath, as there is no public API to set
- // the matrix for form objects. (yet)
static constexpr FS_MATRIX kMatrix = {0.5f, 0.0f, 0.0f, 0.5f, 0.0f, 0.0f};
- CPDF_FormObject* pFormObj =
- CPDFPageObjectFromFPDFPageObject(page_object)->AsForm();
- pFormObj->Transform(CFXMatrixFromFSMatrix(kMatrix));
- pFormObj->SetDirty(true);
+ EXPECT_TRUE(FPDFPageObj_SetMatrix(page_object, &kMatrix));
FPDFPage_InsertObject(page, page_object);
EXPECT_TRUE(FPDFPage_GenerateContent(page));