Page.AssignWatermark(PageWatermark) Method
Assigns a new watermark to a page’s Page.Watermark property.
Namespace: DevExpress.XtraPrinting
Assembly: DevExpress.Printing.v24.1.Core.dll
NuGet Package: DevExpress.Printing.Core
Declaration
Parameters
Name | Type | Description |
---|---|---|
source | PageWatermark | A PageWatermark object which specifies a new watermark for a page. |
Remarks
When a Document is generated, all its Document.Pages contain a watermark which is specified by the PrintingSystemBase.Watermarks property of a document’s printing system.
To specify individual watermarks for particular pages, use the Page.WatermarkId property or call the Page.AssignWatermark
method.
Example
The following example demonstrates how to specify a unique watermark for different pages in a report. You can do it in the following ways:
Assign the Page.WatermarkId property to the Watermark.Id value.
Call the
Page.AssignWatermark
method for the page whose watermark you want to change, and pass a new watermark to this method as a parameter.
Page.AssignWatermark
takes priority over Page.WatermarkId
.
If you want to remove the watermark from a particular page, pass a new empty watermark to the AssignWatermark
method.
using System;
using System.Drawing;
using System.Windows.Forms;
using DevExpress.Drawing;
using DevExpress.XtraPrinting;
using DevExpress.XtraPrinting.Drawing;
using DevExpress.XtraReports.UI;
// ...
namespace DifferentWatermarks {
public partial class Form1 : Form {
public Form1() {
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e) {
// Create a report and assign a watermark to it.
XtraReport1 report = new XtraReport1();
report.Watermarks.Add(CreateTextWatermark("Common Watermark", "Watermark1"));
report.Watermarks.Add(CreateTextWatermark("Second Page", "Watermark2"));
report.CreateDocument();
// Add a custom watermark to the second page.
Page myPage = report.Pages[1];
myPage.WatermarkId = "Watermark2";
// Remove a watermark from the third page.
myPage = report.Pages[2];
myPage.AssignWatermark(new PageWatermark());
// Show the Print Preview.
report.ShowPreviewDialog();
}
// Create a watermark with the specified text.
private Watermark CreateTextWatermark(string text, string id) {
Watermark textWatermark = new Watermark();
textWatermark.Id = id;
textWatermark.Text = text;
textWatermark.TextDirection = DirectionMode.ForwardDiagonal;
textWatermark.Font = new DXFont(textWatermark.Font.Name, 40);
textWatermark.ForeColor = Color.DodgerBlue;
textWatermark.TextTransparency = 150;
textWatermark.TextPosition = WatermarkPosition.InFront;
return textWatermark;
}
}
}
Related GitHub Examples
The following code snippet (auto-collected from DevExpress Examples) contains a reference to the AssignWatermark(PageWatermark) method.
Note
The algorithm used to collect these code examples remains a work in progress. Accordingly, the links and snippets below may produce inaccurate results. If you encounter an issue with code examples below, please use the feedback form on this page to report the issue.