show_pdf.html 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <!DOCTYPE html><meta charset="utf-8"/>
  2. <link rel="stylesheet" href="{{ url_for('static', filename='css/text_layer_builder.css') }}" />
  3. <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
  4. <script src="//mozilla.github.io/pdf.js/build/pdf.js"></script>
  5. <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}"/>
  6. <script type="javascript" src="//cdnjs.cloudflare.com/ajax/libs/pdf.js/2.3.200/pdf.js"></script>
  7. <!-- das funktioniert!!!!!
  8. <script type="javascript" src="https://unpkg.com/pdfjs-dist@latest/build/pdf.js" ></script>
  9. <script type="javascript" src="{{ url_for('static', filename='js/pdf.js') }}"></script>
  10. <script src="https://mozilla.github.io/pdf.js/build/pdf.js"></script>
  11. -->
  12. <script type="javascript" src="{{ url_for('static', filename='js/text_layer_builder.js') }}"></script>
  13. <script type="javascript" src="{{ url_for('static', filename='js/ui_utils.js') }}"></script>
  14. <body>
  15. <div id="container"> {{og_filename}}</div>
  16. <script>
  17. var og_filename = "{{og_filename}}";
  18. var url = "{{ url_for('send_file', filename=og_filename) }}";
  19. console.log(og_filename);
  20. var pdfjsLib = window['pdfjs-dist/build/pdf'];
  21. pdfjsLib.getDocument(url)
  22. .promise.then(function(pdf) {
  23. // Get div#container and cache it for later use
  24. var container = document.getElementById("container");
  25. // Loop from 1 to total_number_of_pages in PDF document
  26. for (var i = 1; i <= pdf.numPages; i++) {
  27. // Get desired page
  28. pdf.getPage(i).then(function(page) {
  29. var scale = 1.5;
  30. var viewport = page.getViewport({scale: scale});
  31. var div = document.createElement("div");
  32. // Set id attribute with page-#{pdf_page_number} format
  33. div.setAttribute("id", "page-" + (page.pageIndex + 1));
  34. // This will keep positions of child elements as per our needs
  35. div.setAttribute("style", "position: relative");
  36. // Append div within div#container
  37. container.appendChild(div);
  38. // Create a new Canvas element
  39. var canvas = document.createElement("canvas");
  40. // Append Canvas within div#page-#{pdf_page_number}
  41. div.appendChild(canvas);
  42. var context = canvas.getContext('2d');
  43. canvas.height = viewport.height;
  44. canvas.width = viewport.width;
  45. var renderContext = {
  46. canvasContext: context,
  47. viewport: viewport
  48. };
  49. // Render PDF page
  50. page.render(renderContext)
  51. .promise.then(function() {
  52. // Get text-fragments
  53. return page.getTextContent();
  54. console.log(textContent);
  55. })
  56. .then(function(textContent) {
  57. // Create div which will hold text-fragments
  58. var textLayerDiv = document.createElement("div");
  59. // Set it's class to textLayer which have required CSS styles
  60. textLayerDiv.setAttribute("class", "textLayer");
  61. // Append newly created div in `div#page-#{pdf_page_number}`
  62. div.appendChild(textLayerDiv);
  63. // Create new instance of TextLayerBuilder class
  64. var textLayer = new TextLayerBuilder({
  65. textLayerDiv: textLayerDiv,
  66. pageIndex: page.pageIndex,
  67. viewport: viewport
  68. });
  69. // Set text-fragments
  70. textLayer.setTextContent(textContent);
  71. // Render text-fragments
  72. textLayer.render();
  73. });
  74. });
  75. }
  76. });
  77. </script>
  78. </body>
  79. </html>