Work-around for HighlightAnnotations without a top-level /ExtGState-entry (issue 13242)
For HighlightAnnotations with a built-in appearance stream, we still rely on it to specify the opacity correctly via a suitable blend mode. However, if the Annotation-drawing operators are placed *within* a /XObject of the /Form-type, the /ExtGState won't apply to the final rendering and the result is that the highlighting obscures the underlying text. The more *correct* and general solution would likely be to somehow modify the implementation in `src/display/canvas.js`, to special-case handling of /Form-type /XObjects when rendering Annotations. Since we can very easily work-around this problem for now by using the "no appearance stream" code-path, doing *something* here ought to be preferable. This patch is (obviously) merely a work-around, but given that the referenced issue is (as far as I know) the first case we've seen of this problem a simple solution will hopefully suffice for now.
This commit is contained in:
parent
e499521b78
commit
707a9e3b02
@ -2676,7 +2676,17 @@ class HighlightAnnotation extends MarkupAnnotation {
|
||||
null
|
||||
));
|
||||
if (quadPoints) {
|
||||
if (!this.appearance) {
|
||||
const resources =
|
||||
this.appearance && this.appearance.dict.get("Resources");
|
||||
|
||||
if (!this.appearance || !(resources && resources.has("ExtGState"))) {
|
||||
if (this.appearance) {
|
||||
// Workaround for cases where there's no /ExtGState-entry directly
|
||||
// available, e.g. when the appearance stream contains a /XObject of
|
||||
// the /Form-type, since that causes the highlighting to completely
|
||||
// obsure the PDF content below it (fixes issue13242.pdf).
|
||||
warn("HighlightAnnotation - ignoring built-in appearance stream.");
|
||||
}
|
||||
// Default color is yellow in Acrobat Reader
|
||||
const fillColor = this.color
|
||||
? Array.from(this.color).map(c => c / 255)
|
||||
|
1
test/pdfs/.gitignore
vendored
1
test/pdfs/.gitignore
vendored
@ -254,6 +254,7 @@
|
||||
!find_all.pdf
|
||||
!helloworld-bad.pdf
|
||||
!zerowidthline.pdf
|
||||
!issue13242.pdf
|
||||
!js-colors.pdf
|
||||
!annotation-line-without-appearance-empty-Rect.pdf
|
||||
!issue12841_reduced.pdf
|
||||
|
BIN
test/pdfs/issue13242.pdf
Normal file
BIN
test/pdfs/issue13242.pdf
Normal file
Binary file not shown.
@ -2324,6 +2324,13 @@
|
||||
"lastPage": 1,
|
||||
"type": "eq"
|
||||
},
|
||||
{ "id": "issue13242",
|
||||
"file": "pdfs/issue13242.pdf",
|
||||
"md5": "ceb2da908c972087eb90e6bae240bce9",
|
||||
"rounds": 1,
|
||||
"type": "eq",
|
||||
"annotations": true
|
||||
},
|
||||
{ "id": "issue7229",
|
||||
"file": "pdfs/issue7229.pdf",
|
||||
"md5": "480e51aae0ac271780e4603d1561d15e",
|
||||
|
Loading…
Reference in New Issue
Block a user