16
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

埋め込んだPDFを印刷させない方法(PDF.js)

Posted at

はじめに

  • PDF.jsを使用
  • そのものをいじリます
  • 全てCSSだけで対応可能
  • PDF直接見られた時は対応不可(一般ユーザはそこまでたどり着かないと想定)

実装方法

まず埋め込む


<iframe src="web/viewer.html?file=../sample.pdf"></iframe>

ファイルのパスは適宜変更。

印刷時、PDF部分を表示させない

viewer.cssに下記追加


@media print {
  body {
    display: none;
  }
}

印刷画面では、エリアだけ保持され、その部分が表示されない。
開発者しかやらないと思うが、仮に埋め込んだURLにアクセスされ、そこで印刷しても表示されない。
※PDF本来のURLに直アクセスされれば、印刷もDLもできてしまうが、一般ユーザの操作ではそこまでできないと想定

余分なボタンを消す

さっきと同じく、viewer.cssに下記追加。


#print, #secondaryPrint {
  display: none !important;
}

ブラウザ上で操作される印刷ボタンを消す
↓こういう部分
toobar.png

toobar2.png

ダウンロードもさせたくなければ、適宜IDを調べて、そのボタンも消す。

ツールバーを消す

いっそのことツールバーを消したほうがスッキリかも…?
その場合は、ツールバーの高さ分だけ変な余白ができるので、#viewerContainerの位置を調整する。

.toolbar {
  display: none;
}
#viewerContainer {
  top: 0;
}
16
19
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?