0

Although I've succeeded in making an image be as large as it can be, and centered onto a webpage, I cannot seem to get Firefox to print this image centered onto the page at max size. You can see the page here, and ctrl+p should show a print-preview.

While the image is centered properly on the web page, notice that it is not centered in the print-preview or upon the printed page.

html,body{margin:0; padding:0;} 
@media all
{
  img
  {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100vh;
  }
}
@page{size: landscape letter;}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Protractor</title>
</head>
<body>
    <img src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" style="font-size:16.4px;stroke-width:.81" viewBox="0 0 456 264"><text x="224" y="-401" style="fill:#121513;stroke:#3465a4" transform="rotate(90)">0</text><text x="214" y="-419" style="fill:#121513;stroke:#3465a4" transform="rotate(90)">180</text><text x="254" y="-359" style="fill:#121513;stroke:#3465a4" transform="rotate(80)">10</text><text x="248" y="-377" style="fill:#121513;stroke:#3465a4" transform="rotate(80)">170</text><text x="284" y="-310" style="fill:#121513;stroke:#3465a4" transform="rotate(70)">20</text><text x="276" y="-329" style="fill:#121513;stroke:#3465a4" transform="rotate(70)">160</text><text x="304" y="-257" style="fill:#121513;stroke:#3465a4" transform="rotate(60)">30</text><text x="295" y="-275" style="fill:#121513;stroke:#3465a4" transform="rotate(60)">150</text><text x="312" y="-201" style="fill:#121513;stroke:#3465a4" transform="rotate(50)">40</text><text x="306" y="-221" style="fill:#121513;stroke:#3465a4" transform="rotate(50)">140</text><text x="311" y="-147" style="fill:#121513;stroke:#3465a4" transform="rotate(40)">50</text><text x="307" y="-164" style="fill:#121513;stroke:#3465a4" transform="rotate(40)">130</text><text x="302" y="-91" style="fill:#121513;stroke:#3465a4" transform="rotate(30)">60</text><text x="297" y="-110" style="fill:#121513;stroke:#3465a4" transform="rotate(30)">120</text><text x="284" y="-38" style="fill:#121513;stroke:#3465a4" transform="rotate(20)">70</text><text x="278" y="-57" style="fill:#121513;stroke:#3465a4" transform="rotate(20)">110</text><text x="257" y="10" style="fill:#121513;stroke:#3465a4" transform="rotate(10)">80</text><text x="250" y="-8" style="fill:#121513;stroke:#3465a4" transform="rotate(10)">100</text><text x="213" y="45" style="font-size:27.9px;fill:#121513;stroke:#3465a4;stroke-width:1.37">90</text><text x="171" y="89" style="fill:#121513;stroke:#3465a4" transform="rotate(-10)">100</text><text x="177" y="71" style="fill:#121513;stroke:#3465a4" transform="rotate(-10)">80</text><text x="123" y="117" style="fill:#121513;stroke:#3465a4" transform="rotate(-20)">110</text><text x="129" y="100" style="fill:#121513;stroke:#3465a4" transform="rotate(-20)">70</text><text x="69" y="136" style="fill:#121513;stroke:#3465a4" transform="rotate(-30)">120</text><text x="75" y="118" style="fill:#121513;stroke:#3465a4" transform="rotate(-30)">60</text><text x="13" y="146" style="fill:#121513;stroke:#3465a4" transform="rotate(-40)">130</text><text x="19" y="128" style="fill:#121513;stroke:#3465a4" transform="rotate(-40)">50</text><text x="-42" y="147" style="fill:#121513;stroke:#3465a4" transform="rotate(-50)">140</text><text x="-38" y="128" style="fill:#121513;stroke:#3465a4" transform="rotate(-50)">40</text><text x="-98" y="136" style="fill:#121513;stroke:#3465a4" transform="rotate(-60)">150</text><text x="-95" y="119" style="fill:#121513;stroke:#3465a4" transform="rotate(-60)">30</text><text x="-151" y="117" style="fill:#121513;stroke:#3465a4" transform="rotate(-70)">160</text><text x="-148" y="100" style="fill:#121513;stroke:#3465a4" transform="rotate(-70)">20</text><text x="-201" y="89" style="fill:#121513;stroke:#3465a4" transform="rotate(-80)">170</text><text x="-197" y="71" style="fill:#121513;stroke:#3465a4" transform="rotate(-80)">10</text><text x="-246" y="52" style="fill:#121513;stroke:#3465a4" transform="rotate(-90)">180</text><text x="-234" y="34" style="fill:#121513;stroke:#3465a4" transform="rotate(-90)">0</text><path d="M228 1A227 227 0 0 0 3 263h449A227 227 0 0 0 228 1z" style="color:#000;overflow:visible;fill:none;stroke:#3465a4;stroke-width:1.39;stroke-linejoin:round"/><path d="M585 300h25" style="fill:none;stroke:#3465a4;stroke-width:4.09" transform="translate(8 9) scale(.73328)"/><path d="m584 275 25-2" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m330 295 197-35" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m581 251 24-5m-30-20 24-6" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m328 290 188-69" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m568 203 23-9m-33-14 23-11" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m326 285 173-100" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m547 158 21-13m-35-8 21-15" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m323 281 153-129" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m518 117 19-16" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m502 98 17-17" style="fill:none;stroke:#3465a4;stroke-width:4.09" transform="translate(8 9) scale(.73328)"/><path d="m319 277 129-153" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m483 82 16-19m-36 4 15-21" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m315 274 100-173" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m443 53 12-21m-35 10 11-23" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m310 272 69-188" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m397 32 9-23m-32 16 6-24" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="m305 270 35-197" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m349 19 5-24m-29 21 2-25" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M300 270V70" style="fill:none;stroke:#3465a4;stroke-width:2.95" transform="matrix(.17496 0 0 .94607 176 -6)"/><path d="M300 15v-25" style="fill:none;stroke:#3465a4;stroke-width:4.18" transform="translate(8 9) scale(.73328)"/><path d="m275 16-2-25" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M295 270 260 73" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m251 19-5-24m-20 30-6-24" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M290 272 221 84" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m203 32-9-23m-14 33-11-23" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M285 274 185 101" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m158 53-13-21m-8 35-15-21" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M281 277 152 124" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m117 82-16-19" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M98 98 81 81" style="fill:none;stroke:#3465a4;stroke-width:4.09" transform="translate(8 9) scale(.73328)"/><path d="M277 281 124 152" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m82 117-19-16m4 36-21-15" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M274 285 101 185" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m53 158-21-13m10 35-23-11" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M272 290 84 221" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m32 203-23-9m16 32-24-6" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M270 295 73 260" style="fill:none;stroke:#3465a4;stroke-width:1.23" transform="translate(8 9) scale(.73328)"/><path d="m19 251-24-5m21 29-25-2" style="fill:none;stroke:#3465a4;stroke-width:1.88" transform="translate(8 9) scale(.73328)"/><path d="M270 300H70" style="fill:none;stroke:#3465a4;stroke-width:1.08" transform="matrix(1.67227 0 0 .73328 -57 9)"/><path d="M15 300h-25" style="fill:none;stroke:#3465a4;stroke-width:4.09" transform="translate(8 9) scale(.73328)"/><circle cx="228" cy="228" r="21.3" style="color:#000;overflow:visible;fill:none;stroke:#3465a4;stroke-width:1.38;stroke-linejoin:round"/><path d="M228 229 388 68M228 229 67 68" style="fill:none;stroke:#3465a4;stroke-width:1;stroke-dasharray:8,8"/><path d="M0 229h11" style="fill:none;stroke:#3465a4;stroke-width:.4"/><use width="100%" height="100%"/><use width="100%" height="100%" transform="rotate(1 228 229)"/><use width="100%" height="100%" transform="rotate(2 228 229)"/><use width="100%" height="100%" transform="rotate(3 228 229)"/><use width="100%" height="100%" transform="rotate(4 228 229)"/><use width="100%" height="100%" transform="rotate(6 228 229)"/><use width="100%" height="100%" transform="rotate(7 228 229)"/><use width="100%" height="100%" transform="rotate(8 228 229)"/><use width="100%" height="100%" transform="rotate(9 228 229)"/><use width="100%" height="100%" transform="rotate(11 228 229)"/><use width="100%" height="100%" transform="rotate(12 228 229)"/><use width="100%" height="100%" transform="rotate(13 228 229)"/><use width="100%" height="100%" transform="rotate(14 228 229)"/><use width="100%" height="100%" transform="rotate(16 228 229)"/><use width="100%" height="100%" transform="rotate(17 228 229)"/><use width="100%" height="100%" transform="rotate(18 228 229)"/><use width="100%" height="100%" transform="rotate(19 228 229)"/><use width="100%" height="100%" transform="rotate(21 228 229)"/><use width="100%" height="100%" transform="rotate(22 228 229)"/><use width="100%" height="100%" transform="rotate(23 228 229)"/><use width="100%" height="100%" transform="rotate(24 228 229)"/><use width="100%" height="100%" transform="rotate(26 228 229)"/><use width="100%" height="100%" transform="rotate(27 228 229)"/><use width="100%" height="100%" transform="rotate(28 228 229)"/><use width="100%" height="100%" transform="rotate(29 228 229)"/><use width="100%" height="100%" transform="rotate(31 228 229)"/><use width="100%" height="100%" transform="rotate(32 228 229)"/><use width="100%" height="100%" transform="rotate(33 228 229)"/><use width="100%" height="100%" transform="rotate(34 228 229)"/><use width="100%" height="100%" transform="rotate(36 228 229)"/><use width="100%" height="100%" transform="rotate(37 228 229)"/><use width="100%" height="100%" transform="rotate(38 228 229)"/><use width="100%" height="100%" transform="rotate(39 228 229)"/><use width="100%" height="100%" transform="rotate(41 228 229)"/><use width="100%" height="100%" transform="rotate(42 228 229)"/><use width="100%" height="100%" transform="rotate(43 228 229)"/><use width="100%" height="100%" transform="rotate(44 228 229)"/><use width="100%" height="100%" transform="rotate(46 228 229)"/><use width="100%" height="100%" transform="rotate(47 228 229)"/><use width="100%" height="100%" transform="rotate(48 228 229)"/><use width="100%" height="100%" transform="rotate(49 228 229)"/><use width="100%" height="100%" transform="rotate(51 228 229)"/><use width="100%" height="100%" transform="rotate(52 228 229)"/><use width="100%" height="100%" transform="rotate(53 228 229)"/><use width="100%" height="100%" transform="rotate(54 228 229)"/><use width="100%" height="100%" transform="rotate(56 228 229)"/><use width="100%" height="100%" transform="rotate(57 228 229)"/><use width="100%" height="100%" transform="rotate(58 228 229)"/><use width="100%" height="100%" transform="rotate(59 228 229)"/><use width="100%" height="100%" transform="rotate(61 228 229)"/><use width="100%" height="100%" transform="rotate(62 228 229)"/><use width="100%" height="100%" transform="rotate(63 228 229)"/><use width="100%" height="100%" transform="rotate(64 228 229)"/><use width="100%" height="100%" transform="rotate(66 228 229)"/><use width="100%" height="100%" transform="rotate(67 228 229)"/><use width="100%" height="100%" transform="rotate(68 228 229)"/><use width="100%" height="100%" transform="rotate(69 228 229)"/><use width="100%" height="100%" transform="rotate(71 228 229)"/><use width="100%" height="100%" transform="rotate(72 228 229)"/><use width="100%" height="100%" transform="rotate(73 228 229)"/><use width="100%" height="100%" transform="rotate(74 228 229)"/><use width="100%" height="100%" transform="rotate(76 228 229)"/><use width="100%" height="100%" transform="rotate(77 228 229)"/><use width="100%" height="100%" transform="rotate(78 228 229)"/><use width="100%" height="100%" transform="rotate(79 228 229)"/><use width="100%" height="100%" transform="rotate(81 228 229)"/><use width="100%" height="100%" transform="rotate(82 228 229)"/><use width="100%" height="100%" transform="rotate(83 228 229)"/><use width="100%" height="100%" transform="rotate(84 228 229)"/><use width="100%" height="100%" transform="rotate(86 228 229)"/><use width="100%" height="100%" transform="rotate(87 228 229)"/><use width="100%" height="100%" transform="rotate(88 228 229)"/><use width="100%" height="100%" transform="rotate(89 228 229)"/><use width="100%" height="100%" transform="rotate(91 228 229)"/><use width="100%" height="100%" transform="rotate(92 228 229)"/><use width="100%" height="100%" transform="rotate(93 228 229)"/><use width="100%" height="100%" transform="rotate(94 228 229)"/><use width="100%" height="100%" transform="rotate(96 228 229)"/><use width="100%" height="100%" transform="rotate(97 228 229)"/><use width="100%" height="100%" transform="rotate(98 228 229)"/><use width="100%" height="100%" transform="rotate(99 228 229)"/><use width="100%" height="100%" transform="rotate(101 228 229)"/><use width="100%" height="100%" transform="rotate(102 228 229)"/><use width="100%" height="100%" transform="rotate(103 228 229)"/><use width="100%" height="100%" transform="rotate(104 228 229)"/><use width="100%" height="100%" transform="rotate(106 228 229)"/><use width="100%" height="100%" transform="rotate(107 228 229)"/><use width="100%" height="100%" transform="rotate(108 228 229)"/><use width="100%" height="100%" transform="rotate(109 228 229)"/><use width="100%" height="100%" transform="rotate(111 228 229)"/><use width="100%" height="100%" transform="rotate(112 228 229)"/><use width="100%" height="100%" transform="rotate(113 228 229)"/><use width="100%" height="100%" transform="rotate(114 228 229)"/><use width="100%" height="100%" transform="rotate(116 228 229)"/><use width="100%" height="100%" transform="rotate(117 228 229)"/><use width="100%" height="100%" transform="rotate(118 228 229)"/><use width="100%" height="100%" transform="rotate(119 228 229)"/><use width="100%" height="100%" transform="rotate(121 228 229)"/><use width="100%" height="100%" transform="rotate(122 228 229)"/><use width="100%" height="100%" transform="rotate(123 228 229)"/><use width="100%" height="100%" transform="rotate(124 228 229)"/><use width="100%" height="100%" transform="rotate(126 228 229)"/><use width="100%" height="100%" transform="rotate(127 228 229)"/><use width="100%" height="100%" transform="rotate(128 228 229)"/><use width="100%" height="100%" transform="rotate(129 228 229)"/><use width="100%" height="100%" transform="rotate(131 228 229)"/><use width="100%" height="100%" transform="rotate(132 228 229)"/><use width="100%" height="100%" transform="rotate(133 228 229)"/><use width="100%" height="100%" transform="rotate(134 228 229)"/><use width="100%" height="100%" transform="rotate(136 228 229)"/><use width="100%" height="100%" transform="rotate(137 228 229)"/><use width="100%" height="100%" transform="rotate(138 228 229)"/><use width="100%" height="100%" transform="rotate(139 228 229)"/><use width="100%" height="100%" transform="rotate(141 228 229)"/><use width="100%" height="100%" transform="rotate(142 228 229)"/><use width="100%" height="100%" transform="rotate(143 228 229)"/><use width="100%" height="100%" transform="rotate(144 228 229)"/><use width="100%" height="100%" transform="rotate(146 228 229)"/><use width="100%" height="100%" transform="rotate(147 228 229)"/><use width="100%" height="100%" transform="rotate(148 228 229)"/><use width="100%" height="100%" transform="rotate(149 228 229)"/><use width="100%" height="100%" transform="rotate(151 228 229)"/><use width="100%" height="100%" transform="rotate(152 228 229)"/><use width="100%" height="100%" transform="rotate(153 228 229)"/><use width="100%" height="100%" transform="rotate(154 228 229)"/><use width="100%" height="100%" transform="rotate(156 228 229)"/><use width="100%" height="100%" transform="rotate(157 228 229)"/><use width="100%" height="100%" transform="rotate(158 228 229)"/><use width="100%" height="100%" transform="rotate(159 228 229)"/><use width="100%" height="100%" transform="rotate(161 228 229)"/><use width="100%" height="100%" transform="rotate(162 228 229)"/><use width="100%" height="100%" transform="rotate(163 228 229)"/><use width="100%" height="100%" transform="rotate(164 228 229)"/><use width="100%" height="100%" transform="rotate(166 228 229)"/><use width="100%" height="100%" transform="rotate(167 228 229)"/><use width="100%" height="100%" transform="rotate(168 228 229)"/><use width="100%" height="100%" transform="rotate(169 228 229)"/><use width="100%" height="100%" transform="rotate(171 228 229)"/><use width="100%" height="100%" transform="rotate(172 228 229)"/><use width="100%" height="100%" transform="rotate(173 228 229)"/><use width="100%" height="100%" transform="rotate(174 228 229)"/><use width="100%" height="100%" transform="rotate(176 228 229)"/><use width="100%" height="100%" transform="rotate(177 228 229)"/><use width="100%" height="100%" transform="rotate(178 228 229)"/><use width="100%" height="100%" transform="rotate(179 228 229)"/></svg>">
</body>
</html>

In chromium based browsers, the image does print in the center of the page. How can I get it to also do this Firefox?

Additionally, using CSS, how can I remove the extra information (example: url and timestamp) that browsers print onto the page?

I basically want the image to be as large as it can be on the printed page, landscaped, centered, and without any page info also printed.

Lonnie Best
  • 9,936
  • 10
  • 57
  • 97
  • [Here](https://stackoverflow.com/a/14975912/217867), I found that `@page { margin: 0; }` removes the URL and Timestamp from the printed page. However, in Firefox, the image still doesn't print in the center of the page, nor does it print as large as it does in Chromium. This [print-preview](https://i.imgur.com/Oudwk9A.png) shows that the print job will produce a "less than maximum sized image" that is not centered. How can I fix this? – Lonnie Best Oct 17 '22 at 21:19
  • 1
    This is what I'm seeing in Firefox. It is centered. If yours is not centered, then there's an issue with a setting of your browser: [Firefox (with headers/footers](https://i.imgur.com/ZGRpIP7.png). In the next image, I've removed the headers and footers, but this is a setting in your print dialog. [Firefox (without headers/footers)](https://i.imgur.com/xTBqQKy.png) – Millhorn Oct 18 '22 at 17:00

1 Answers1

1

You can try using @media print {} and assign specific classes/properties within that print query. I've done this quite a bit. In the snippet below, I've included a sample.

Updated

I've included a couple things that will display in the snippet view, but when you click "Print", those elements will not appear.

The print button and the phrase "This message will not display when you click print." will go away when you hit print.

let print = document.querySelector('.print');

print.addEventListener('click', function() {
  window.print();
})
body {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
}

.print {
  padding: 5px 10px;
  border: 0;
  background-color: #5CBF54;
  transition: all .3s ease;
}

.print:hover {
  background-color: #479D3E;
}

.print-msg {
  display: block;
}

@media print {
  body {
    color: black;
  }
  
  .print-msg {
    display: none;
  }
  
  .print {
    display: none;
  }
}
<div class="container">
  <button type="button" class="print">Print</button>
  <h1>Hello World</h1>
  <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Illo qui minus quo culpa consequatur laboriosam, repudiandae maiores explicabo quas debitis beatae fugiat ad provident recusandae animi voluptates nisi accusamus delectus.</p>
  <h2 class="print-msg">This message will not display when you click print.</h2>
</div>
Millhorn
  • 2,953
  • 7
  • 39
  • 77
  • Well, I'm already using `@media all`. It is my understanding that css rules placed in `@media all` also apply to print media. However, I did try changing `@media all` to `@media print`. This had no effect on the print-preview in Firefox; it still prints the image left of center, instead of center (as desired). – Lonnie Best Oct 17 '22 at 19:08
  • 1
    Don't change the entire thing to `@media print {}`. This type of media query works like any other media query. You have to set up your default styles, and then custom styles go within the media query. I've updated my answer with some more information. – Millhorn Oct 18 '22 at 16:31