Merge pull request #285 from vingtetun/master
Unify the multi_page_viewer and the classic viewer.
This commit is contained in:
		
						commit
						710c3da3e3
					
				
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 1.9 KiB | 
							
								
								
									
										199
									
								
								web/images/go-down.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										199
									
								
								web/images/go-down.svg
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,199 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||||
|  | <svg | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||||
|  |    xmlns:cc="http://web.resource.org/cc/" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:xlink="http://www.w3.org/1999/xlink" | ||||||
|  |    xmlns:sodipodi="http://inkscape.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    sodipodi:docname="go-down.svg" | ||||||
|  |    sodipodi:docbase="/home/tigert/cvs/freedesktop.org/tango-icon-theme/scalable/actions" | ||||||
|  |    inkscape:version="0.43+devel" | ||||||
|  |    sodipodi:version="0.32" | ||||||
|  |    id="svg11300" | ||||||
|  |    height="48px" | ||||||
|  |    width="48px" | ||||||
|  |    inkscape:export-filename="/home/jimmac/Desktop/wi-fi.png" | ||||||
|  |    inkscape:export-xdpi="90.000000" | ||||||
|  |    inkscape:export-ydpi="90.000000" | ||||||
|  |    inkscape:output_extension="org.inkscape.output.svg.inkscape"> | ||||||
|  |   <defs | ||||||
|  |      id="defs3"> | ||||||
|  |     <linearGradient | ||||||
|  |        id="linearGradient1442"> | ||||||
|  |       <stop | ||||||
|  |          id="stop1444" | ||||||
|  |          offset="0" | ||||||
|  |          style="stop-color:#73d216" /> | ||||||
|  |       <stop | ||||||
|  |          id="stop1446" | ||||||
|  |          offset="1.0000000" | ||||||
|  |          style="stop-color:#4e9a06" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <linearGradient | ||||||
|  |        id="linearGradient8662" | ||||||
|  |        inkscape:collect="always"> | ||||||
|  |       <stop | ||||||
|  |          id="stop8664" | ||||||
|  |          offset="0" | ||||||
|  |          style="stop-color:#000000;stop-opacity:1;" /> | ||||||
|  |       <stop | ||||||
|  |          id="stop8666" | ||||||
|  |          offset="1" | ||||||
|  |          style="stop-color:#000000;stop-opacity:0;" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <linearGradient | ||||||
|  |        id="linearGradient8650" | ||||||
|  |        inkscape:collect="always"> | ||||||
|  |       <stop | ||||||
|  |          id="stop8652" | ||||||
|  |          offset="0" | ||||||
|  |          style="stop-color:#ffffff;stop-opacity:1;" /> | ||||||
|  |       <stop | ||||||
|  |          id="stop8654" | ||||||
|  |          offset="1" | ||||||
|  |          style="stop-color:#ffffff;stop-opacity:0;" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <radialGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient8662" | ||||||
|  |        id="radialGradient1444" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="matrix(1.000000,0.000000,0.000000,0.536723,1.614716e-15,16.87306)" | ||||||
|  |        cx="24.837126" | ||||||
|  |        cy="36.421127" | ||||||
|  |        fx="24.837126" | ||||||
|  |        fy="36.421127" | ||||||
|  |        r="15.644737" /> | ||||||
|  |     <radialGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient1442" | ||||||
|  |        id="radialGradient1469" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="matrix(1.871885e-16,-0.843022,1.020168,2.265228e-16,0.606436,42.58614)" | ||||||
|  |        cx="35.292667" | ||||||
|  |        cy="20.494493" | ||||||
|  |        fx="35.292667" | ||||||
|  |        fy="20.494493" | ||||||
|  |        r="16.956199" /> | ||||||
|  |     <radialGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient8650" | ||||||
|  |        id="radialGradient1471" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="matrix(3.749427e-16,-2.046729,-1.557610,-2.853404e-16,44.11559,66.93275)" | ||||||
|  |        cx="15.987216" | ||||||
|  |        cy="1.5350308" | ||||||
|  |        fx="15.987216" | ||||||
|  |        fy="1.5350308" | ||||||
|  |        r="17.171415" /> | ||||||
|  |   </defs> | ||||||
|  |   <sodipodi:namedview | ||||||
|  |      inkscape:window-y="25" | ||||||
|  |      inkscape:window-x="0" | ||||||
|  |      inkscape:window-height="885" | ||||||
|  |      inkscape:window-width="1280" | ||||||
|  |      inkscape:showpageshadow="false" | ||||||
|  |      inkscape:document-units="px" | ||||||
|  |      inkscape:grid-bbox="true" | ||||||
|  |      showgrid="false" | ||||||
|  |      inkscape:current-layer="layer1" | ||||||
|  |      inkscape:cy="23.239067" | ||||||
|  |      inkscape:cx="30.291728" | ||||||
|  |      inkscape:zoom="11.313708" | ||||||
|  |      inkscape:pageshadow="2" | ||||||
|  |      inkscape:pageopacity="0.0" | ||||||
|  |      borderopacity="0.25490196" | ||||||
|  |      bordercolor="#666666" | ||||||
|  |      pagecolor="#ffffff" | ||||||
|  |      id="base" | ||||||
|  |      fill="#4e9a06" | ||||||
|  |      stroke="#4e9a06" /> | ||||||
|  |   <metadata | ||||||
|  |      id="metadata4"> | ||||||
|  |     <rdf:RDF> | ||||||
|  |       <cc:Work | ||||||
|  |          rdf:about=""> | ||||||
|  |         <dc:format>image/svg+xml</dc:format> | ||||||
|  |         <dc:type | ||||||
|  |            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||||
|  |         <dc:creator> | ||||||
|  |           <cc:Agent> | ||||||
|  |             <dc:title>Jakub Steiner</dc:title> | ||||||
|  |           </cc:Agent> | ||||||
|  |         </dc:creator> | ||||||
|  |         <dc:source>http://jimmac.musichall.cz</dc:source> | ||||||
|  |         <cc:license | ||||||
|  |            rdf:resource="http://creativecommons.org/licenses/by-sa/2.0/" /> | ||||||
|  |         <dc:title>Go Down</dc:title> | ||||||
|  |         <dc:subject> | ||||||
|  |           <rdf:Bag> | ||||||
|  |             <rdf:li>go</rdf:li> | ||||||
|  |             <rdf:li>lower</rdf:li> | ||||||
|  |             <rdf:li>down</rdf:li> | ||||||
|  |             <rdf:li>arrow</rdf:li> | ||||||
|  |             <rdf:li>pointer</rdf:li> | ||||||
|  |             <rdf:li>></rdf:li> | ||||||
|  |           </rdf:Bag> | ||||||
|  |         </dc:subject> | ||||||
|  |         <dc:contributor> | ||||||
|  |           <cc:Agent> | ||||||
|  |             <dc:title>Andreas Nilsson</dc:title> | ||||||
|  |           </cc:Agent> | ||||||
|  |         </dc:contributor> | ||||||
|  |       </cc:Work> | ||||||
|  |       <cc:License | ||||||
|  |          rdf:about="http://creativecommons.org/licenses/by-sa/2.0/"> | ||||||
|  |         <cc:permits | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Reproduction" /> | ||||||
|  |         <cc:permits | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Distribution" /> | ||||||
|  |         <cc:requires | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Notice" /> | ||||||
|  |         <cc:requires | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Attribution" /> | ||||||
|  |         <cc:permits | ||||||
|  |            rdf:resource="http://web.resource.org/cc/DerivativeWorks" /> | ||||||
|  |         <cc:requires | ||||||
|  |            rdf:resource="http://web.resource.org/cc/ShareAlike" /> | ||||||
|  |       </cc:License> | ||||||
|  |     </rdf:RDF> | ||||||
|  |   </metadata> | ||||||
|  |   <g | ||||||
|  |      inkscape:groupmode="layer" | ||||||
|  |      inkscape:label="Layer 1" | ||||||
|  |      id="layer1"> | ||||||
|  |     <path | ||||||
|  |        transform="matrix(1.214466,0.000000,0.000000,0.595458,-6.163846,16.31275)" | ||||||
|  |        d="M 40.481863 36.421127 A 15.644737 8.3968935 0 1 1  9.1923885,36.421127 A 15.644737 8.3968935 0 1 1  40.481863 36.421127 z" | ||||||
|  |        sodipodi:ry="8.3968935" | ||||||
|  |        sodipodi:rx="15.644737" | ||||||
|  |        sodipodi:cy="36.421127" | ||||||
|  |        sodipodi:cx="24.837126" | ||||||
|  |        id="path8660" | ||||||
|  |        style="opacity:0.20454545;color:#000000;fill:url(#radialGradient1444);fill-opacity:1.0000000;fill-rule:evenodd;stroke:none;stroke-width:1.0000000;stroke-linecap:butt;stroke-linejoin:miter;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1.0000000;visibility:visible;display:inline;overflow:visible" | ||||||
|  |        sodipodi:type="arc" /> | ||||||
|  |     <g | ||||||
|  |        id="g1464" | ||||||
|  |        transform="matrix(-1.000000,0.000000,0.000000,-1.000000,47.02856,43.99921)"> | ||||||
|  |       <path | ||||||
|  |          style="opacity:1.0000000;color:#000000;fill:url(#radialGradient1469);fill-opacity:1.0000000;fill-rule:evenodd;stroke:#3a7304;stroke-width:1.0000004;stroke-linecap:round;stroke-linejoin:round;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1;visibility:visible;display:inline;overflow:visible" | ||||||
|  |          d="M 14.519136,38.500000 L 32.524165,38.496094 L 32.524165,25.504468 L 40.519531,25.496656 L 23.374809,5.4992135 L 6.5285585,25.497284 L 14.524440,25.501074 L 14.519136,38.500000 z " | ||||||
|  |          id="path8643" | ||||||
|  |          sodipodi:nodetypes="cccccccc" /> | ||||||
|  |       <path | ||||||
|  |          style="opacity:0.50802141;color:#000000;fill:url(#radialGradient1471);fill-opacity:1.0000000;fill-rule:evenodd;stroke:none;stroke-width:1.0000000;stroke-linecap:round;stroke-linejoin:round;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1.0000000;visibility:visible;display:inline;overflow:visible" | ||||||
|  |          d="M 39.429889,24.993467 L 32.023498,25.005186 L 32.026179,37.998023 L 16.647623,37.98887 C 17.417545,19.64788 27.370272,26.995797 32.029282,16.341991 L 39.429889,24.993467 z " | ||||||
|  |          id="path8645" | ||||||
|  |          sodipodi:nodetypes="cccccc" /> | ||||||
|  |       <path | ||||||
|  |          sodipodi:nodetypes="cccccccc" | ||||||
|  |          id="path8658" | ||||||
|  |          d="M 15.520704,37.496094 L 31.522109,37.500000 L 31.522109,24.507050 L 38.338920,24.491425 L 23.384644,7.0388396 L 8.6781173,24.495782 L 15.518018,24.501029 L 15.520704,37.496094 z " | ||||||
|  |          style="opacity:0.48128340;color:#000000;fill:none;fill-opacity:1.0000000;fill-rule:evenodd;stroke:#ffffff;stroke-width:1.0000004;stroke-linecap:butt;stroke-linejoin:miter;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1.0000000;visibility:visible;display:inline;overflow:visible" /> | ||||||
|  |     </g> | ||||||
|  |   </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 8.1 KiB | 
							
								
								
									
										195
									
								
								web/images/go-up.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										195
									
								
								web/images/go-up.svg
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,195 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||||
|  | <svg | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||||
|  |    xmlns:cc="http://web.resource.org/cc/" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:xlink="http://www.w3.org/1999/xlink" | ||||||
|  |    xmlns:sodipodi="http://inkscape.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    sodipodi:docname="go-up.svg" | ||||||
|  |    sodipodi:docbase="/home/tigert/cvs/freedesktop.org/tango-icon-theme/scalable/actions" | ||||||
|  |    inkscape:version="0.43+devel" | ||||||
|  |    sodipodi:version="0.32" | ||||||
|  |    id="svg11300" | ||||||
|  |    height="48px" | ||||||
|  |    width="48px" | ||||||
|  |    inkscape:export-filename="/home/jimmac/Desktop/wi-fi.png" | ||||||
|  |    inkscape:export-xdpi="90.000000" | ||||||
|  |    inkscape:export-ydpi="90.000000" | ||||||
|  |    inkscape:output_extension="org.inkscape.output.svg.inkscape"> | ||||||
|  |   <defs | ||||||
|  |      id="defs3"> | ||||||
|  |     <linearGradient | ||||||
|  |        id="linearGradient2304"> | ||||||
|  |       <stop | ||||||
|  |          id="stop2306" | ||||||
|  |          offset="0" | ||||||
|  |          style="stop-color:#73d216" /> | ||||||
|  |       <stop | ||||||
|  |          id="stop2308" | ||||||
|  |          offset="1.0000000" | ||||||
|  |          style="stop-color:#4e9a06" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <linearGradient | ||||||
|  |        id="linearGradient8662" | ||||||
|  |        inkscape:collect="always"> | ||||||
|  |       <stop | ||||||
|  |          id="stop8664" | ||||||
|  |          offset="0" | ||||||
|  |          style="stop-color:#000000;stop-opacity:1;" /> | ||||||
|  |       <stop | ||||||
|  |          id="stop8666" | ||||||
|  |          offset="1" | ||||||
|  |          style="stop-color:#000000;stop-opacity:0;" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <linearGradient | ||||||
|  |        id="linearGradient8650" | ||||||
|  |        inkscape:collect="always"> | ||||||
|  |       <stop | ||||||
|  |          id="stop8652" | ||||||
|  |          offset="0" | ||||||
|  |          style="stop-color:#ffffff;stop-opacity:1;" /> | ||||||
|  |       <stop | ||||||
|  |          id="stop8654" | ||||||
|  |          offset="1" | ||||||
|  |          style="stop-color:#ffffff;stop-opacity:0;" /> | ||||||
|  |     </linearGradient> | ||||||
|  |     <radialGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient8650" | ||||||
|  |        id="radialGradient1438" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="matrix(-3.749427e-16,-2.046729,1.557610,-2.853404e-16,2.767009,66.93275)" | ||||||
|  |        cx="24.53788" | ||||||
|  |        cy="0.40010813" | ||||||
|  |        fx="24.53788" | ||||||
|  |        fy="0.40010813" | ||||||
|  |        r="17.171415" /> | ||||||
|  |     <radialGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient2304" | ||||||
|  |        id="radialGradient1441" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="matrix(1.871885e-16,-0.843022,1.020168,2.265228e-16,0.606436,42.58614)" | ||||||
|  |        cx="11.319205" | ||||||
|  |        cy="22.454971" | ||||||
|  |        fx="11.319205" | ||||||
|  |        fy="22.454971" | ||||||
|  |        r="16.956199" /> | ||||||
|  |     <radialGradient | ||||||
|  |        inkscape:collect="always" | ||||||
|  |        xlink:href="#linearGradient8662" | ||||||
|  |        id="radialGradient1444" | ||||||
|  |        gradientUnits="userSpaceOnUse" | ||||||
|  |        gradientTransform="matrix(1.000000,0.000000,0.000000,0.536723,1.614716e-15,16.87306)" | ||||||
|  |        cx="24.837126" | ||||||
|  |        cy="36.421127" | ||||||
|  |        fx="24.837126" | ||||||
|  |        fy="36.421127" | ||||||
|  |        r="15.644737" /> | ||||||
|  |   </defs> | ||||||
|  |   <sodipodi:namedview | ||||||
|  |      inkscape:window-y="25" | ||||||
|  |      inkscape:window-x="0" | ||||||
|  |      inkscape:window-height="885" | ||||||
|  |      inkscape:window-width="1280" | ||||||
|  |      inkscape:showpageshadow="false" | ||||||
|  |      inkscape:document-units="px" | ||||||
|  |      inkscape:grid-bbox="true" | ||||||
|  |      showgrid="false" | ||||||
|  |      inkscape:current-layer="layer1" | ||||||
|  |      inkscape:cy="25.620377" | ||||||
|  |      inkscape:cx="22.042915" | ||||||
|  |      inkscape:zoom="13.059378" | ||||||
|  |      inkscape:pageshadow="2" | ||||||
|  |      inkscape:pageopacity="0.0" | ||||||
|  |      borderopacity="0.25490196" | ||||||
|  |      bordercolor="#666666" | ||||||
|  |      pagecolor="#ffffff" | ||||||
|  |      id="base" | ||||||
|  |      fill="#73d216" | ||||||
|  |      stroke="#73d216" /> | ||||||
|  |   <metadata | ||||||
|  |      id="metadata4"> | ||||||
|  |     <rdf:RDF> | ||||||
|  |       <cc:Work | ||||||
|  |          rdf:about=""> | ||||||
|  |         <dc:format>image/svg+xml</dc:format> | ||||||
|  |         <dc:type | ||||||
|  |            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||||
|  |         <dc:creator> | ||||||
|  |           <cc:Agent> | ||||||
|  |             <dc:title>Jakub Steiner</dc:title> | ||||||
|  |           </cc:Agent> | ||||||
|  |         </dc:creator> | ||||||
|  |         <dc:source>http://jimmac.musichall.cz</dc:source> | ||||||
|  |         <cc:license | ||||||
|  |            rdf:resource="http://creativecommons.org/licenses/by-sa/2.0/" /> | ||||||
|  |         <dc:title>Go Up</dc:title> | ||||||
|  |         <dc:subject> | ||||||
|  |           <rdf:Bag> | ||||||
|  |             <rdf:li>go</rdf:li> | ||||||
|  |             <rdf:li>higher</rdf:li> | ||||||
|  |             <rdf:li>up</rdf:li> | ||||||
|  |             <rdf:li>arrow</rdf:li> | ||||||
|  |             <rdf:li>pointer</rdf:li> | ||||||
|  |             <rdf:li>></rdf:li> | ||||||
|  |           </rdf:Bag> | ||||||
|  |         </dc:subject> | ||||||
|  |         <dc:contributor> | ||||||
|  |           <cc:Agent> | ||||||
|  |             <dc:title>Andreas Nilsson</dc:title> | ||||||
|  |           </cc:Agent> | ||||||
|  |         </dc:contributor> | ||||||
|  |       </cc:Work> | ||||||
|  |       <cc:License | ||||||
|  |          rdf:about="http://creativecommons.org/licenses/by-sa/2.0/"> | ||||||
|  |         <cc:permits | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Reproduction" /> | ||||||
|  |         <cc:permits | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Distribution" /> | ||||||
|  |         <cc:requires | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Notice" /> | ||||||
|  |         <cc:requires | ||||||
|  |            rdf:resource="http://web.resource.org/cc/Attribution" /> | ||||||
|  |         <cc:permits | ||||||
|  |            rdf:resource="http://web.resource.org/cc/DerivativeWorks" /> | ||||||
|  |         <cc:requires | ||||||
|  |            rdf:resource="http://web.resource.org/cc/ShareAlike" /> | ||||||
|  |       </cc:License> | ||||||
|  |     </rdf:RDF> | ||||||
|  |   </metadata> | ||||||
|  |   <g | ||||||
|  |      inkscape:groupmode="layer" | ||||||
|  |      inkscape:label="Layer 1" | ||||||
|  |      id="layer1"> | ||||||
|  |     <path | ||||||
|  |        transform="matrix(1.214466,0.000000,0.000000,0.595458,-6.163846,16.31275)" | ||||||
|  |        d="M 40.481863 36.421127 A 15.644737 8.3968935 0 1 1  9.1923885,36.421127 A 15.644737 8.3968935 0 1 1  40.481863 36.421127 z" | ||||||
|  |        sodipodi:ry="8.3968935" | ||||||
|  |        sodipodi:rx="15.644737" | ||||||
|  |        sodipodi:cy="36.421127" | ||||||
|  |        sodipodi:cx="24.837126" | ||||||
|  |        id="path8660" | ||||||
|  |        style="opacity:0.29946521;color:#000000;fill:url(#radialGradient1444);fill-opacity:1.0000000;fill-rule:evenodd;stroke:none;stroke-width:1.0000000;stroke-linecap:butt;stroke-linejoin:miter;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1.0000000;visibility:visible;display:inline;overflow:visible" | ||||||
|  |        sodipodi:type="arc" /> | ||||||
|  |     <path | ||||||
|  |        sodipodi:nodetypes="cccccccc" | ||||||
|  |        id="path8643" | ||||||
|  |        d="M 14.491792,38.500000 L 32.469477,38.500000 L 32.469477,25.547437 L 40.500000,25.547437 L 23.374809,5.4992135 L 6.5285585,25.489471 L 14.497096,25.555762 L 14.491792,38.500000 z " | ||||||
|  |        style="opacity:1.0000000;color:#000000;fill:url(#radialGradient1441);fill-opacity:1.0000000;fill-rule:evenodd;stroke:#3a7304;stroke-width:1.0000004;stroke-linecap:round;stroke-linejoin:round;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1;visibility:visible;display:inline;overflow:visible" /> | ||||||
|  |     <path | ||||||
|  |        sodipodi:nodetypes="cccscc" | ||||||
|  |        id="path8645" | ||||||
|  |        d="M 7.5855237,25.03253 L 14.995821,25.03253 L 15.062422,31.594339 C 20.718034,20.593878 31.055517,22.749928 31.656768,15.966674 C 31.656768,15.966674 23.366938,6.4219692 23.366938,6.4219692 L 7.5855237,25.03253 z " | ||||||
|  |        style="opacity:0.50802141;color:#000000;fill:url(#radialGradient1438);fill-opacity:1.0000000;fill-rule:evenodd;stroke:none;stroke-width:1.0000000;stroke-linecap:round;stroke-linejoin:round;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1.0000000;visibility:visible;display:inline;overflow:visible" /> | ||||||
|  |     <path | ||||||
|  |        style="opacity:0.48128340;color:#000000;fill:none;fill-opacity:1.0000000;fill-rule:evenodd;stroke:#ffffff;stroke-width:1.0000004;stroke-linecap:butt;stroke-linejoin:miter;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:10.000000;stroke-dasharray:none;stroke-dashoffset:0.0000000;stroke-opacity:1.0000000;visibility:visible;display:inline;overflow:visible" | ||||||
|  |        d="M 15.602735,37.500000 L 31.502578,37.500000 L 31.502578,24.507050 L 38.311576,24.507050 L 23.361206,7.0700896 L 8.6546798,24.550470 L 15.475049,24.528373 L 15.602735,37.500000 z " | ||||||
|  |        id="path8658" | ||||||
|  |        sodipodi:nodetypes="cccccccc" /> | ||||||
|  |   </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 8.0 KiB | 
										
											Binary file not shown.
										
									
								
							| @ -1,296 +0,0 @@ | |||||||
| /* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- / |  | ||||||
| /* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */ |  | ||||||
| 
 |  | ||||||
| body { |  | ||||||
|   background-color: #929292; |  | ||||||
|   font-family: 'Lucida Grande', 'Lucida Sans Unicode', Helvetica, Arial, Verdana, sans-serif; |  | ||||||
|   margin: 0px; |  | ||||||
|   padding: 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| canvas { |  | ||||||
|   box-shadow: 0px 4px 10px #000; |  | ||||||
|   -moz-box-shadow: 0px 4px 10px #000; |  | ||||||
|   -webkit-box-shadow: 0px 4px 10px #000; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| span { |  | ||||||
|   font-size: 0.8em; |  | ||||||
|   text-shadow: 0px 1px 0px #fff; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .control { |  | ||||||
|   display: inline-block; |  | ||||||
|   float: left; |  | ||||||
|   margin: 0px 20px 0px 0px; |  | ||||||
|   padding: 0px 4px 0px 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .control > input { |  | ||||||
|   float: left; |  | ||||||
|   border: 1px solid #4d4d4d; |  | ||||||
|   height: 20px; |  | ||||||
|   padding: 0px; |  | ||||||
|   margin: 0px 2px 0px 0px; |  | ||||||
|   border-radius: 3px; |  | ||||||
|   -moz-border-radius: 3px; |  | ||||||
|   -webkit-border-radius: 3px; |  | ||||||
|   box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.3); |  | ||||||
|   -moz-box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.3); |  | ||||||
|   -webkit-box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.3); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .control > select { |  | ||||||
|   float: left; |  | ||||||
|   border: 1px solid #4d4d4d; |  | ||||||
|   height: 22px; |  | ||||||
|   padding: 2px 0px 0px; |  | ||||||
|   margin: 0px 0px 1px; |  | ||||||
|   border-radius: 3px; |  | ||||||
|   -moz-border-radius: 3px; |  | ||||||
|   -webkit-border-radius: 3px; |  | ||||||
|   box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.3); |  | ||||||
|   -moz-box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.3); |  | ||||||
|   -webkit-box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.3); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .control > span { |  | ||||||
|   cursor: default; |  | ||||||
|   float: left; |  | ||||||
|   height: 18px; |  | ||||||
|   margin: 5px 2px 0px; |  | ||||||
|   padding: 0px; |  | ||||||
|   user-select: none; |  | ||||||
|   -moz-user-select: none; |  | ||||||
|   -webkit-user-select: none; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .control .label { |  | ||||||
|   clear: both; |  | ||||||
|   float: left; |  | ||||||
|   font-size: 0.65em; |  | ||||||
|   margin: 2px 0px 0px; |  | ||||||
|   position: relative; |  | ||||||
|   text-align: center; |  | ||||||
|   width: 100%; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .thumbnailPageNumber { |  | ||||||
|   color: #fff; |  | ||||||
|   font-size: 0.55em; |  | ||||||
|   text-align: right; |  | ||||||
|   margin: -6px 2px 6px 0px; |  | ||||||
|   width: 102px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .thumbnail { |  | ||||||
|   width: 104px; |  | ||||||
|   height: 134px; |  | ||||||
|   margin: 0px auto 10px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .page { |  | ||||||
|   width: 816px; |  | ||||||
|   height: 1056px; |  | ||||||
|   margin: 10px auto; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #controls { |  | ||||||
|   background-color: #eee; |  | ||||||
|   background: -moz-linear-gradient(center bottom, #ddd 0%, #fff 100%); |  | ||||||
|   background: -webkit-gradient(linear, left bottom, left top, color-stop(0.0, #ddd), color-stop(1.0, #fff)); |  | ||||||
|   border-bottom: 1px solid #666; |  | ||||||
|   padding: 4px 0px 0px 8px; |  | ||||||
|   position: fixed; |  | ||||||
|   left: 0px; |  | ||||||
|   top: 0px; |  | ||||||
|   height: 40px; |  | ||||||
|   width: 100%; |  | ||||||
|   box-shadow: 0px 2px 8px #000; |  | ||||||
|   -moz-box-shadow: 0px 2px 8px #000; |  | ||||||
|   -webkit-box-shadow: 0px 2px 8px #000; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #controls input { |  | ||||||
|   user-select: text; |  | ||||||
|   -moz-user-select: text; |  | ||||||
|   -webkit-user-select: text; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| button { |  | ||||||
|   background-color: #ddd; |  | ||||||
|   background: -moz-linear-gradient(center bottom, #c3c3c3 0%, #f3f3f3 100%); |  | ||||||
|   background: -webkit-gradient(linear, left bottom, left top, color-stop(0.0, #c3c3c3), color-stop(1.0, #f3f3f3)); |  | ||||||
|   border: 1px solid #4d4d4d; |  | ||||||
|   cursor: default; |  | ||||||
|   float: left; |  | ||||||
|   margin: 0px 0px 1px; |  | ||||||
|   width: 29px; |  | ||||||
|   height: 22px; |  | ||||||
| 	border-radius: 3px; |  | ||||||
| 	-moz-border-radius: 3px; |  | ||||||
| 	-webkit-border-radius: 3px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| button:disabled { |  | ||||||
|   background-color: #eee; |  | ||||||
|   background: -moz-linear-gradient(center bottom, #ddd 0%, #fff 100%); |  | ||||||
|   background: -webkit-gradient(linear, left bottom, left top, color-stop(0.0, #ddd), color-stop(1.0, #fff)); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| button:disabled > span { |  | ||||||
|   opacity: 0.3; |  | ||||||
|   -moz-opacity: 0.3; |  | ||||||
|   -webkit-opacity: 0.3; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| button.down { |  | ||||||
|   background-color: #777; |  | ||||||
|   background: -moz-linear-gradient(center bottom, #888 0%, #555 100%); |  | ||||||
|   background: -webkit-gradient(linear, left bottom, left top, color-stop(0.0, #888), color-stop(1.0, #555)); |  | ||||||
|   box-shadow: inset 0px 0px 2px rgba(0, 0, 0, 0.8); |  | ||||||
|   -moz-box-shadow: inset 0px 0px 2px rgba(0, 0, 0, 0.8); |  | ||||||
|   -webkit-box-shadow: inset 0px 0px 2px rgba(0, 0, 0, 0.8); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #previousPageButton { |  | ||||||
|   width: 28px; |  | ||||||
|   border-right: 0px; |  | ||||||
|   border-top-right-radius: 0px; |  | ||||||
|   border-bottom-right-radius: 0px; |  | ||||||
|   -moz-border-radius-topright: 0px; |  | ||||||
|   -moz-border-radius-bottomright: 0px; |  | ||||||
|   -webkit-border-top-right-radius: 0px; |  | ||||||
|   -webkit-border-bottom-right-radius: 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #previousPageButton > span { |  | ||||||
|   background: url('images/buttons.png') no-repeat 0px 0px; |  | ||||||
|   display: inline-block; |  | ||||||
|   width: 19px; |  | ||||||
|   height: 19px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #nextPageButton { |  | ||||||
|   width: 28px; |  | ||||||
|   border-top-left-radius: 0px; |  | ||||||
|   border-bottom-left-radius: 0px; |  | ||||||
|   -moz-border-radius-topleft: 0px; |  | ||||||
|   -moz-border-radius-bottomleft: 0px; |  | ||||||
|   -webkit-border-top-left-radius: 0px; |  | ||||||
|   -webkit-border-bottom-left-radius: 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #nextPageButton > span { |  | ||||||
|   background: url('images/buttons.png') no-repeat -19px 0px; |  | ||||||
|   display: inline-block; |  | ||||||
|   width: 19px; |  | ||||||
|   height: 19px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #singleLayoutButton { |  | ||||||
|   width: 28px; |  | ||||||
|   border-right: 0px; |  | ||||||
|   border-top-right-radius: 0px; |  | ||||||
|   border-bottom-right-radius: 0px; |  | ||||||
|   -moz-border-radius-topright: 0px; |  | ||||||
|   -moz-border-radius-bottomright: 0px; |  | ||||||
|   -webkit-border-top-right-radius: 0px; |  | ||||||
|   -webkit-border-bottom-right-radius: 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #singleLayoutButton > span { |  | ||||||
|   background: url('images/buttons.png') no-repeat -57px 0px; |  | ||||||
|   display: inline-block; |  | ||||||
|   width: 19px; |  | ||||||
|   height: 19px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #splitLayoutButton { |  | ||||||
|   width: 28px; |  | ||||||
|   border-top-left-radius: 0px; |  | ||||||
|   border-bottom-left-radius: 0px; |  | ||||||
|   -moz-border-radius-topleft: 0px; |  | ||||||
|   -moz-border-radius-bottomleft: 0px; |  | ||||||
|   -webkit-border-top-left-radius: 0px; |  | ||||||
|   -webkit-border-bottom-left-radius: 0px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #splitLayoutButton > span { |  | ||||||
|   background: url('images/buttons.png') no-repeat -76px 0px; |  | ||||||
|   display: inline-block; |  | ||||||
|   width: 19px; |  | ||||||
|   height: 19px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #openFileButton { |  | ||||||
|   margin-left: 3px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #openFileButton > span { |  | ||||||
|   background: url('images/buttons.png') no-repeat -38px 0px; |  | ||||||
|   display: inline-block; |  | ||||||
|   width: 19px; |  | ||||||
|   height: 19px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #fileInput { |  | ||||||
|   display: none; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #pageNumber { |  | ||||||
|   text-align: right; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #sidebar { |  | ||||||
|   position: fixed; |  | ||||||
|   width: 200px; |  | ||||||
|   top: 62px; |  | ||||||
|   bottom: 18px; |  | ||||||
|   left: -140px; |  | ||||||
|   transition: left 0.25s ease-in-out 1s; |  | ||||||
|   -moz-transition: left 0.25s ease-in-out 1s; |  | ||||||
|   -webkit-transition: left 0.25s ease-in-out 1s; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #sidebar:hover { |  | ||||||
|   left: 0px; |  | ||||||
|   transition: left 0.25s ease-in-out 0s; |  | ||||||
|   -moz-transition: left 0.25s ease-in-out 0s; |  | ||||||
|   -webkit-transition: left 0.25s ease-in-out 0s; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #sidebarBox { |  | ||||||
|   background-color: rgba(0, 0, 0, 0.7); |  | ||||||
|   width: 150px; |  | ||||||
|   height: 100%; |  | ||||||
|   border-top-right-radius: 8px; |  | ||||||
|   border-bottom-right-radius: 8px; |  | ||||||
|   -moz-border-radius-topright: 8px; |  | ||||||
|   -moz-border-radius-bottomright: 8px; |  | ||||||
|   -webkit-border-top-right-radius: 8px; |  | ||||||
|   -webkit-border-bottom-right-radius: 8px; |  | ||||||
|   box-shadow: 0px 2px 8px #000; |  | ||||||
|   -moz-box-shadow: 0px 2px 8px #000; |  | ||||||
|   -webkit-box-shadow: 0px 2px 8px #000; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #sidebarScrollView { |  | ||||||
|   position: absolute; |  | ||||||
|   overflow: hidden; |  | ||||||
|   overflow-y: auto; |  | ||||||
|   top: 10px; |  | ||||||
|   bottom: 10px; |  | ||||||
|   left: 10px; |  | ||||||
|   width: 130px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #sidebarContentView { |  | ||||||
|   height: auto; |  | ||||||
|   width: 100px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #viewer { |  | ||||||
|   margin: 44px 0px 0px; |  | ||||||
|   padding: 8px 0px; |  | ||||||
| } |  | ||||||
| @ -1,66 +0,0 @@ | |||||||
| <!DOCTYPE html> |  | ||||||
| <html> |  | ||||||
| <head> |  | ||||||
| <title>pdf.js Multi-Page Viewer</title> |  | ||||||
| <meta http-equiv="Content-type" content="text/html;charset=UTF-8"/> |  | ||||||
| <link rel="stylesheet" href="multi_page_viewer.css" type="text/css" media="screen"/> |  | ||||||
| <script type="text/javascript" src="compatibility.js"></script> |  | ||||||
| <script type="text/javascript" src="../pdf.js"></script> |  | ||||||
| <script type="text/javascript" src="../fonts.js"></script> |  | ||||||
| <script type="text/javascript" src="../crypto.js"></script> |  | ||||||
| <script type="text/javascript" src="../glyphlist.js"></script> |  | ||||||
| <script type="text/javascript" src="multi_page_viewer.js"></script> |  | ||||||
| </head> |  | ||||||
| <body> |  | ||||||
|   <div id="controls"> |  | ||||||
|     <span class="control"> |  | ||||||
|       <button id="previousPageButton" disabled="disabled"><span></span></button> |  | ||||||
|       <button id="nextPageButton" disabled="disabled"><span></span></button> |  | ||||||
|       <span class="label">Previous/Next</span> |  | ||||||
|     </span> |  | ||||||
|     <span class="control"> |  | ||||||
|       <input type="text" id="pageNumber" value="1" size="2"/> |  | ||||||
|       <span>/</span> |  | ||||||
|       <span id="numPages">--</span> |  | ||||||
|       <span class="label">Page Number</span> |  | ||||||
|     </span> |  | ||||||
|     <span class="control"> |  | ||||||
|       <select id="scaleSelect"> |  | ||||||
|         <option value="50">50%</option> |  | ||||||
|         <option value="75">75%</option> |  | ||||||
|         <option value="100">100%</option> |  | ||||||
|         <option value="125">125%</option> |  | ||||||
|         <option value="150" selected="selected">150%</option> |  | ||||||
|         <option value="200">200%</option> |  | ||||||
|       </select> |  | ||||||
|       <span class="label">Zoom</span> |  | ||||||
|     </span> |  | ||||||
|      |  | ||||||
|     <!-- WIP: Leave commented out until implemented --> |  | ||||||
|     <!-- |  | ||||||
|     <span class="control"> |  | ||||||
|       <button id="singleLayoutButton" class="selected"><span></span></button> |  | ||||||
|       <button id="splitLayoutButton"><span></span></button> |  | ||||||
|       <span class="label">Page Layout</span> |  | ||||||
|     </span> |  | ||||||
|     --> |  | ||||||
|      |  | ||||||
|     <span class="control" id="fileWrapper"> |  | ||||||
|       <button id="openFileButton"><span></span></button> |  | ||||||
|       <input type="file" id="fileInput"/> |  | ||||||
|       <span class="label">Open File</span> |  | ||||||
|     </span> |  | ||||||
|   </div> |  | ||||||
|    |  | ||||||
|   <!-- EXPERIMENTAL: Slide-out sidebar with page thumbnails (comment-out to disable) --> |  | ||||||
|   <div id="sidebar"> |  | ||||||
|     <div id="sidebarBox"> |  | ||||||
|       <div id="sidebarScrollView"> |  | ||||||
|         <div id="sidebarContentView"></div> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
|   </div> |  | ||||||
|    |  | ||||||
|   <div id="viewer"></div> |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
| @ -1,513 +0,0 @@ | |||||||
| /* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- / |  | ||||||
| /* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */ |  | ||||||
| 
 |  | ||||||
| 'use strict'; |  | ||||||
| 
 |  | ||||||
| var pageTimeout; |  | ||||||
| 
 |  | ||||||
| var PDFViewer = { |  | ||||||
|   queryParams: {}, |  | ||||||
| 
 |  | ||||||
|   element: null, |  | ||||||
| 
 |  | ||||||
|   sidebarContentView: null, |  | ||||||
| 
 |  | ||||||
|   previousPageButton: null, |  | ||||||
|   nextPageButton: null, |  | ||||||
|   pageNumberInput: null, |  | ||||||
|   scaleSelect: null, |  | ||||||
|   fileInput: null, |  | ||||||
| 
 |  | ||||||
|   willJumpToPage: false, |  | ||||||
| 
 |  | ||||||
|   pdf: null, |  | ||||||
| 
 |  | ||||||
|   url: 'compressed.tracemonkey-pldi-09.pdf', |  | ||||||
|   pageNumber: 1, |  | ||||||
|   numberOfPages: 1, |  | ||||||
| 
 |  | ||||||
|   scale: 1.0, |  | ||||||
| 
 |  | ||||||
|   pageWidth: function(page) { |  | ||||||
|     var pdfToCssUnitsCoef = 96.0 / 72.0; |  | ||||||
|     var width = (page.mediaBox[2] - page.mediaBox[0]); |  | ||||||
|     return width * PDFViewer.scale * pdfToCssUnitsCoef; |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   pageHeight: function(page) { |  | ||||||
|     var pdfToCssUnitsCoef = 96.0 / 72.0; |  | ||||||
|     var height = (page.mediaBox[3] - page.mediaBox[1]); |  | ||||||
|     return height * PDFViewer.scale * pdfToCssUnitsCoef; |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   lastPagesDrawn: [], |  | ||||||
| 
 |  | ||||||
|   visiblePages: function() { |  | ||||||
|     var pageBottomMargin = 10; |  | ||||||
|     var windowTop = window.pageYOffset; |  | ||||||
|     var windowBottom = window.pageYOffset + window.innerHeight; |  | ||||||
| 
 |  | ||||||
|     var pageHeight, page; |  | ||||||
|     var i, n = PDFViewer.numberOfPages, currentHeight = pageBottomMargin; |  | ||||||
|     for (i = 1; i <= n; i++) { |  | ||||||
|       var page = PDFViewer.pdf.getPage(i); |  | ||||||
|       pageHeight = PDFViewer.pageHeight(page) + pageBottomMargin; |  | ||||||
|       if (currentHeight + pageHeight > windowTop) |  | ||||||
|         break; |  | ||||||
|       currentHeight += pageHeight; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     var pages = []; |  | ||||||
|     for (; i <= n && currentHeight < windowBottom; i++) { |  | ||||||
|       var page = PDFViewer.pdf.getPage(i); |  | ||||||
|       pageHeight = PDFViewer.pageHeight(page) + pageBottomMargin; |  | ||||||
|       currentHeight += pageHeight; |  | ||||||
|       pages.push(i); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     return pages; |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   createThumbnail: function(num) { |  | ||||||
|     if (PDFViewer.sidebarContentView) { |  | ||||||
|       var anchor = document.createElement('a'); |  | ||||||
|       anchor.href = '#' + num; |  | ||||||
| 
 |  | ||||||
|       var containerDiv = document.createElement('div'); |  | ||||||
|       containerDiv.id = 'thumbnailContainer' + num; |  | ||||||
|       containerDiv.className = 'thumbnail'; |  | ||||||
| 
 |  | ||||||
|       var pageNumberDiv = document.createElement('div'); |  | ||||||
|       pageNumberDiv.className = 'thumbnailPageNumber'; |  | ||||||
|       pageNumberDiv.innerHTML = '' + num; |  | ||||||
| 
 |  | ||||||
|       anchor.appendChild(containerDiv); |  | ||||||
|       PDFViewer.sidebarContentView.appendChild(anchor); |  | ||||||
|       PDFViewer.sidebarContentView.appendChild(pageNumberDiv); |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   removeThumbnail: function(num) { |  | ||||||
|     var div = document.getElementById('thumbnailContainer' + num); |  | ||||||
| 
 |  | ||||||
|     if (div) { |  | ||||||
|       while (div.hasChildNodes()) { |  | ||||||
|         div.removeChild(div.firstChild); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   drawThumbnail: function(num) { |  | ||||||
|     if (!PDFViewer.pdf) |  | ||||||
|       return; |  | ||||||
| 
 |  | ||||||
|     var div = document.getElementById('thumbnailContainer' + num); |  | ||||||
| 
 |  | ||||||
|     if (div && !div.hasChildNodes()) { |  | ||||||
|       var page = PDFViewer.pdf.getPage(num); |  | ||||||
|       var canvas = document.createElement('canvas'); |  | ||||||
| 
 |  | ||||||
|       canvas.id = 'thumbnail' + num; |  | ||||||
|       canvas.mozOpaque = true; |  | ||||||
| 
 |  | ||||||
|       var pageWidth = PDFViewer.pageWidth(page); |  | ||||||
|       var pageHeight = PDFViewer.pageHeight(page); |  | ||||||
|       var thumbScale = Math.min(104 / pageWidth, 134 / pageHeight); |  | ||||||
|       canvas.width = pageWidth * thumbScale; |  | ||||||
|       canvas.height = pageHeight * thumbScale; |  | ||||||
|       div.appendChild(canvas); |  | ||||||
| 
 |  | ||||||
|       var ctx = canvas.getContext('2d'); |  | ||||||
|       ctx.save(); |  | ||||||
|       ctx.fillStyle = 'rgb(255, 255, 255)'; |  | ||||||
|       ctx.fillRect(0, 0, canvas.width, canvas.height); |  | ||||||
|       ctx.restore(); |  | ||||||
| 
 |  | ||||||
|       page.startRendering(ctx, function() { }); |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   createPage: function(num) { |  | ||||||
|     var page = PDFViewer.pdf.getPage(num); |  | ||||||
| 
 |  | ||||||
|     var anchor = document.createElement('a'); |  | ||||||
|     anchor.name = '' + num; |  | ||||||
| 
 |  | ||||||
|     var div = document.createElement('div'); |  | ||||||
|     div.id = 'pageContainer' + num; |  | ||||||
|     div.className = 'page'; |  | ||||||
|     div.style.width = PDFViewer.pageWidth(page) + 'px'; |  | ||||||
|     div.style.height = PDFViewer.pageHeight(page) + 'px'; |  | ||||||
| 
 |  | ||||||
|     PDFViewer.element.appendChild(anchor); |  | ||||||
|     PDFViewer.element.appendChild(div); |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   removePage: function(num) { |  | ||||||
|     var div = document.getElementById('pageContainer' + num); |  | ||||||
| 
 |  | ||||||
|     if (div) { |  | ||||||
|       while (div.hasChildNodes()) { |  | ||||||
|         div.removeChild(div.firstChild); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   drawPage: function(num) { |  | ||||||
|     if (!PDFViewer.pdf) |  | ||||||
|       return; |  | ||||||
| 
 |  | ||||||
|     var div = document.getElementById('pageContainer' + num); |  | ||||||
| 
 |  | ||||||
|     if (div && !div.hasChildNodes()) { |  | ||||||
|       var page = PDFViewer.pdf.getPage(num); |  | ||||||
|       var canvas = document.createElement('canvas'); |  | ||||||
| 
 |  | ||||||
|       canvas.id = 'page' + num; |  | ||||||
|       canvas.mozOpaque = true; |  | ||||||
| 
 |  | ||||||
|       canvas.width = PDFViewer.pageWidth(page); |  | ||||||
|       canvas.height = PDFViewer.pageHeight(page); |  | ||||||
|       div.appendChild(canvas); |  | ||||||
| 
 |  | ||||||
|       var ctx = canvas.getContext('2d'); |  | ||||||
|       ctx.save(); |  | ||||||
|       ctx.fillStyle = 'rgb(255, 255, 255)'; |  | ||||||
|       ctx.fillRect(0, 0, canvas.width, canvas.height); |  | ||||||
|       ctx.restore(); |  | ||||||
| 
 |  | ||||||
|       page.startRendering(ctx, function() { }); |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   changeScale: function(num) { |  | ||||||
|     while (PDFViewer.element.hasChildNodes()) { |  | ||||||
|       PDFViewer.element.removeChild(PDFViewer.element.firstChild); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PDFViewer.scale = num / 100; |  | ||||||
| 
 |  | ||||||
|     var i; |  | ||||||
| 
 |  | ||||||
|     if (PDFViewer.pdf) { |  | ||||||
|       for (i = 1; i <= PDFViewer.numberOfPages; i++) { |  | ||||||
|         PDFViewer.createPage(i); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     for (i = 0; i < PDFViewer.scaleSelect.childNodes; i++) { |  | ||||||
|       var option = PDFViewer.scaleSelect.childNodes[i]; |  | ||||||
| 
 |  | ||||||
|       if (option.value == num) { |  | ||||||
|         if (!option.selected) { |  | ||||||
|           option.selected = 'selected'; |  | ||||||
|         } |  | ||||||
|       } else { |  | ||||||
|         if (option.selected) { |  | ||||||
|           option.removeAttribute('selected'); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PDFViewer.scaleSelect.value = Math.floor(PDFViewer.scale * 100) + '%'; |  | ||||||
| 
 |  | ||||||
|     // Clear the array of the last pages drawn to force a redraw.
 |  | ||||||
|     PDFViewer.lastPagesDrawn = []; |  | ||||||
| 
 |  | ||||||
|     // Jump the scroll position to the correct page.
 |  | ||||||
|     PDFViewer.goToPage(PDFViewer.pageNumber); |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   goToPage: function(num) { |  | ||||||
|     if (1 <= num && num <= PDFViewer.numberOfPages) { |  | ||||||
|       PDFViewer.pageNumber = num; |  | ||||||
|       PDFViewer.pageNumberInput.value = PDFViewer.pageNumber; |  | ||||||
|       PDFViewer.willJumpToPage = true; |  | ||||||
| 
 |  | ||||||
|       if (document.location.hash.substr(1) == PDFViewer.pageNumber) |  | ||||||
|         // Force a "scroll event" to redraw
 |  | ||||||
|         setTimeout(window.onscroll, 0); |  | ||||||
|       document.location.hash = PDFViewer.pageNumber; |  | ||||||
| 
 |  | ||||||
|       PDFViewer.previousPageButton.disabled = (PDFViewer.pageNumber === 1); |  | ||||||
|       PDFViewer.nextPageButton.disabled = (PDFViewer.pageNumber === PDFViewer.numberOfPages); |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   goToPreviousPage: function() { |  | ||||||
|     if (PDFViewer.pageNumber > 1) { |  | ||||||
|       PDFViewer.goToPage(--PDFViewer.pageNumber); |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   goToNextPage: function() { |  | ||||||
|     if (PDFViewer.pageNumber < PDFViewer.numberOfPages) { |  | ||||||
|       PDFViewer.goToPage(++PDFViewer.pageNumber); |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   openURL: function(url) { |  | ||||||
|     PDFViewer.url = url; |  | ||||||
|     document.title = url; |  | ||||||
| 
 |  | ||||||
|     if (this.thumbsLoadingInterval) { |  | ||||||
|       // cancel thumbs loading operations
 |  | ||||||
|       clearInterval(this.thumbsLoadingInterval); |  | ||||||
|       this.thumbsLoadingInterval = null; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     var req = new XMLHttpRequest(); |  | ||||||
|     req.open('GET', url); |  | ||||||
|     req.mozResponseType = req.responseType = 'arraybuffer'; |  | ||||||
|     req.expected = (document.URL.indexOf('file:') === 0) ? 0 : 200; |  | ||||||
| 
 |  | ||||||
|     req.onreadystatechange = function() { |  | ||||||
|       if (req.readyState === 4 && req.status === req.expected) { |  | ||||||
|         var data = (req.mozResponseArrayBuffer || req.mozResponse || |  | ||||||
|                     req.responseArrayBuffer || req.response); |  | ||||||
| 
 |  | ||||||
|         PDFViewer.readPDF(data); |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     req.send(null); |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   thumbsLoadingInterval: null, |  | ||||||
| 
 |  | ||||||
|   readPDF: function(data) { |  | ||||||
|     while (PDFViewer.element.hasChildNodes()) { |  | ||||||
|       PDFViewer.element.removeChild(PDFViewer.element.firstChild); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     while (PDFViewer.sidebarContentView.hasChildNodes()) { |  | ||||||
|       PDFViewer.sidebarContentView.removeChild( |  | ||||||
|         PDFViewer.sidebarContentView.firstChild |  | ||||||
|       ); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PDFViewer.pdf = new PDFDoc(new Stream(data)); |  | ||||||
|     PDFViewer.numberOfPages = PDFViewer.pdf.numPages; |  | ||||||
|     document.getElementById('numPages').innerHTML = |  | ||||||
|       PDFViewer.numberOfPages.toString(); |  | ||||||
| 
 |  | ||||||
|     for (var i = 1; i <= PDFViewer.numberOfPages; i++) { |  | ||||||
|       PDFViewer.createPage(i); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     if (PDFViewer.numberOfPages > 0) { |  | ||||||
|       PDFViewer.drawPage(1); |  | ||||||
|       document.location.hash = 1; |  | ||||||
| 
 |  | ||||||
|       // slowly loading the thumbs (few per second)
 |  | ||||||
|       // first time we are loading more images than subsequent
 |  | ||||||
|       var currentPageIndex = 1, imagesToLoad = 15; |  | ||||||
|       this.thumbsLoadingInterval = setInterval((function() { |  | ||||||
|         while (imagesToLoad-- > 0) { |  | ||||||
|           if (currentPageIndex > PDFViewer.numberOfPages) { |  | ||||||
|             clearInterval(this.thumbsLoadingInterval); |  | ||||||
|             this.thumbsLoadingInterval = null; |  | ||||||
|             return; |  | ||||||
|           } |  | ||||||
|           PDFViewer.createThumbnail(currentPageIndex); |  | ||||||
|           PDFViewer.drawThumbnail(currentPageIndex); |  | ||||||
|           ++currentPageIndex; |  | ||||||
|         } |  | ||||||
|         imagesToLoad = 3; // next time loading less images
 |  | ||||||
|       }).bind(this), 500); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PDFViewer.previousPageButton.disabled = (PDFViewer.pageNumber === 1); |  | ||||||
|     PDFViewer.nextPageButton.disabled = (PDFViewer.pageNumber === PDFViewer.numberOfPages); |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| window.onload = function() { |  | ||||||
|   // Parse the URL query parameters into a cached object.
 |  | ||||||
|   PDFViewer.queryParams = function() { |  | ||||||
|     var qs = window.location.search.substring(1); |  | ||||||
|     var kvs = qs.split('&'); |  | ||||||
|     var params = {}; |  | ||||||
| 
 |  | ||||||
|     for (var i = 0; i < kvs.length; ++i) { |  | ||||||
|       var kv = kvs[i].split('='); |  | ||||||
|       params[unescape(kv[0])] = unescape(kv[1]); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     return params; |  | ||||||
|   }(); |  | ||||||
| 
 |  | ||||||
|   PDFViewer.element = document.getElementById('viewer'); |  | ||||||
| 
 |  | ||||||
|   PDFViewer.sidebarContentView = document.getElementById('sidebarContentView'); |  | ||||||
| 
 |  | ||||||
|   PDFViewer.pageNumberInput = document.getElementById('pageNumber'); |  | ||||||
|   PDFViewer.pageNumberInput.onkeydown = function(evt) { |  | ||||||
|     var charCode = evt.charCode || evt.keyCode; |  | ||||||
| 
 |  | ||||||
|     // Up arrow key.
 |  | ||||||
|     if (charCode === 38) { |  | ||||||
|       PDFViewer.goToNextPage(); |  | ||||||
|       this.select(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // Down arrow key.
 |  | ||||||
|     else if (charCode === 40) { |  | ||||||
|       PDFViewer.goToPreviousPage(); |  | ||||||
|       this.select(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // All other non-numeric keys (excluding Left arrow, Right arrow,
 |  | ||||||
|     // Backspace, and Delete keys).
 |  | ||||||
|     else if ((charCode < 48 || charCode > 57) && |  | ||||||
|       charCode !== 8 &&   // Backspace
 |  | ||||||
|       charCode !== 46 &&  // Delete
 |  | ||||||
|       charCode !== 37 &&  // Left arrow
 |  | ||||||
|       charCode !== 39     // Right arrow
 |  | ||||||
|     ) { |  | ||||||
|       return false; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     return true; |  | ||||||
|   }; |  | ||||||
|   PDFViewer.pageNumberInput.onkeyup = function(evt) { |  | ||||||
|     var charCode = evt.charCode || evt.keyCode; |  | ||||||
| 
 |  | ||||||
|     // All numeric keys, Backspace, and Delete.
 |  | ||||||
|     if ((charCode >= 48 && charCode <= 57) || |  | ||||||
|       charCode === 8 ||   // Backspace
 |  | ||||||
|       charCode === 46     // Delete
 |  | ||||||
|     ) { |  | ||||||
|       PDFViewer.goToPage(this.value); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     this.focus(); |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   PDFViewer.previousPageButton = document.getElementById('previousPageButton'); |  | ||||||
|   PDFViewer.previousPageButton.onclick = function(evt) { |  | ||||||
|     PDFViewer.goToPreviousPage(); |  | ||||||
|   }; |  | ||||||
|   PDFViewer.previousPageButton.onmousedown = function(evt) { |  | ||||||
|     this.className = 'down'; |  | ||||||
|   }; |  | ||||||
|   PDFViewer.previousPageButton.onmouseup = function(evt) { |  | ||||||
|     this.className = ''; |  | ||||||
|   }; |  | ||||||
|   PDFViewer.previousPageButton.onmouseout = function(evt) { |  | ||||||
|     this.className = ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   PDFViewer.nextPageButton = document.getElementById('nextPageButton'); |  | ||||||
|   PDFViewer.nextPageButton.onclick = function(evt) { |  | ||||||
|     PDFViewer.goToNextPage(); |  | ||||||
|   }; |  | ||||||
|   PDFViewer.nextPageButton.onmousedown = function(evt) { |  | ||||||
|     this.className = 'down'; |  | ||||||
|   }; |  | ||||||
|   PDFViewer.nextPageButton.onmouseup = function(evt) { |  | ||||||
|     this.className = ''; |  | ||||||
|   }; |  | ||||||
|   PDFViewer.nextPageButton.onmouseout = function(evt) { |  | ||||||
|     this.className = ''; |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   PDFViewer.scaleSelect = document.getElementById('scaleSelect'); |  | ||||||
|   PDFViewer.scaleSelect.onchange = function(evt) { |  | ||||||
|     PDFViewer.changeScale(parseInt(this.value)); |  | ||||||
|   }; |  | ||||||
| 
 |  | ||||||
|   if (window.File && window.FileReader && window.FileList && window.Blob) { |  | ||||||
|     var openFileButton = document.getElementById('openFileButton'); |  | ||||||
|     openFileButton.onclick = function(evt) { |  | ||||||
|       PDFViewer.fileInput.click(); |  | ||||||
|     }; |  | ||||||
|     openFileButton.onmousedown = function(evt) { |  | ||||||
|       this.className = 'down'; |  | ||||||
|     }; |  | ||||||
|     openFileButton.onmouseup = function(evt) { |  | ||||||
|       this.className = ''; |  | ||||||
|     }; |  | ||||||
|     openFileButton.onmouseout = function(evt) { |  | ||||||
|       this.className = ''; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     PDFViewer.fileInput = document.getElementById('fileInput'); |  | ||||||
|     PDFViewer.fileInput.onchange = function(evt) { |  | ||||||
|       var files = evt.target.files; |  | ||||||
| 
 |  | ||||||
|       if (files.length > 0) { |  | ||||||
|         var file = files[0]; |  | ||||||
|         var fileReader = new FileReader(); |  | ||||||
| 
 |  | ||||||
|         document.title = file.name; |  | ||||||
| 
 |  | ||||||
|         // Read the local file into a Uint8Array.
 |  | ||||||
|         fileReader.onload = function(evt) { |  | ||||||
|           var data = evt.target.result; |  | ||||||
|           var buffer = new ArrayBuffer(data.length); |  | ||||||
|           var uint8Array = new Uint8Array(buffer); |  | ||||||
| 
 |  | ||||||
|           for (var i = 0; i < data.length; i++) { |  | ||||||
|             uint8Array[i] = data.charCodeAt(i); |  | ||||||
|           } |  | ||||||
| 
 |  | ||||||
|           PDFViewer.readPDF(uint8Array); |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         // Read as a binary string since "readAsArrayBuffer" is not yet
 |  | ||||||
|         // implemented in Firefox.
 |  | ||||||
|         fileReader.readAsBinaryString(file); |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|     PDFViewer.fileInput.value = null; |  | ||||||
|   } else { |  | ||||||
|     document.getElementById('fileWrapper').style.display = 'none'; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   PDFViewer.pageNumber = |  | ||||||
|     parseInt(PDFViewer.queryParams.page) || PDFViewer.pageNumber; |  | ||||||
|   PDFViewer.scale = parseInt(PDFViewer.scaleSelect.value) / 100 || 1.0; |  | ||||||
| 
 |  | ||||||
|   PDFViewer.openURL(PDFViewer.queryParams.file || PDFViewer.url); |  | ||||||
| 
 |  | ||||||
|   window.onscroll = function(evt) { |  | ||||||
|     var lastPagesDrawn = PDFViewer.lastPagesDrawn; |  | ||||||
|     var visiblePages = PDFViewer.visiblePages(); |  | ||||||
| 
 |  | ||||||
|     var pagesToDraw = []; |  | ||||||
|     var pagesToKeep = []; |  | ||||||
|     var pagesToRemove = []; |  | ||||||
| 
 |  | ||||||
|     var i; |  | ||||||
| 
 |  | ||||||
|     // Determine which visible pages were not previously drawn.
 |  | ||||||
|     for (i = 0; i < visiblePages.length; i++) { |  | ||||||
|       if (lastPagesDrawn.indexOf(visiblePages[i]) === -1) { |  | ||||||
|         pagesToDraw.push(visiblePages[i]); |  | ||||||
|         PDFViewer.drawPage(visiblePages[i]); |  | ||||||
|       } else { |  | ||||||
|         pagesToKeep.push(visiblePages[i]); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // Determine which previously drawn pages are no longer visible.
 |  | ||||||
|     for (i = 0; i < lastPagesDrawn.length; i++) { |  | ||||||
|       if (visiblePages.indexOf(lastPagesDrawn[i]) === -1) { |  | ||||||
|         pagesToRemove.push(lastPagesDrawn[i]); |  | ||||||
|         PDFViewer.removePage(lastPagesDrawn[i]); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PDFViewer.lastPagesDrawn = pagesToDraw.concat(pagesToKeep); |  | ||||||
| 
 |  | ||||||
|     // Update the page number input with the current page number.
 |  | ||||||
|     if (!PDFViewer.willJumpToPage && visiblePages.length > 0) { |  | ||||||
|       PDFViewer.pageNumber = PDFViewer.pageNumberInput.value = visiblePages[0]; |  | ||||||
|       PDFViewer.previousPageButton.disabled = (PDFViewer.pageNumber === 1); |  | ||||||
|       PDFViewer.nextPageButton.disabled = (PDFViewer.pageNumber === PDFViewer.numberOfPages); |  | ||||||
|     } else { |  | ||||||
|       PDFViewer.willJumpToPage = false; |  | ||||||
|     } |  | ||||||
|   }; |  | ||||||
| }; |  | ||||||
							
								
								
									
										122
									
								
								web/viewer.css
									
									
									
									
									
								
							
							
						
						
									
										122
									
								
								web/viewer.css
									
									
									
									
									
								
							| @ -2,35 +2,129 @@ | |||||||
| /* vim: set shiftwidth=4 tabstop=8 autoindent cindent expandtab: */ | /* vim: set shiftwidth=4 tabstop=8 autoindent cindent expandtab: */ | ||||||
| 
 | 
 | ||||||
| body { | body { | ||||||
|     margin: 6px; |   background-color: #929292; | ||||||
|  |   font-family: 'Lucida Grande', 'Lucida Sans Unicode', Helvetica, Arial, Verdana, sans-serif; | ||||||
|  |   margin: 0px; | ||||||
|   padding: 0px; |   padding: 0px; | ||||||
|     background-color: #c0bdb7; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /* === Toolbar === */ | ||||||
| #controls { | #controls { | ||||||
|     position:fixed; |   background-color: #eee; | ||||||
|  |   background: -moz-linear-gradient(center bottom, #eee 0%, #fff 100%); | ||||||
|  |   background: -webkit-gradient(linear, left bottom, left top, color-stop(0.0, #ddd), color-stop(1.0, #fff)); | ||||||
|  |   border-bottom: 1px solid #666; | ||||||
|  |   padding: 4px; | ||||||
|  |   position: fixed; | ||||||
|   left: 0px; |   left: 0px; | ||||||
|   top: 0px; |   top: 0px; | ||||||
|  |   height: 40px; | ||||||
|   width: 100%; |   width: 100%; | ||||||
|     padding: 7px; |  | ||||||
|     border-bottom: 1px solid black; |  | ||||||
|     background-color: rgb(242, 240, 238); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| span#info { | .separator { | ||||||
|     float: right; |   display: inline; | ||||||
|     font: 14px sans-serif; |   border-left: 1px solid #d3d3d3; | ||||||
|     margin-right: 10px; |   border-right: 1px solid #fff; | ||||||
|  |   height: 32px; | ||||||
|  |   width:0px; | ||||||
|  |   margin: 4px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #viewer { | #controls > button { | ||||||
|  |   line-height: 32px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #canvas { | #controls > button[disabled] > img { | ||||||
|     margin: auto; |   opacity: 0.5; | ||||||
|     display: block; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #pageNumber { | #pageNumber { | ||||||
|   text-align: right; |   text-align: right; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | #fileInput { | ||||||
|  |   line-height: 32px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | span#info { | ||||||
|  |   display: none; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | @-moz-document regexp("http:.*debug=1.*") { | ||||||
|  |   span#info { | ||||||
|  |     display: inline-block; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* === Sidebar === */ | ||||||
|  | #sidebar { | ||||||
|  |   position: fixed; | ||||||
|  |   width: 200px; | ||||||
|  |   top: 62px; | ||||||
|  |   bottom: 18px; | ||||||
|  |   left: -140px; | ||||||
|  |   transition: left 0.25s ease-in-out 1s; | ||||||
|  |   -moz-transition: left 0.25s ease-in-out 1s; | ||||||
|  |   -webkit-transition: left 0.25s ease-in-out 1s; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #sidebar:hover { | ||||||
|  |   left: 0px; | ||||||
|  |   transition: left 0.25s ease-in-out 0s; | ||||||
|  |   -moz-transition: left 0.25s ease-in-out 0s; | ||||||
|  |   -webkit-transition: left 0.25s ease-in-out 0s; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #sidebarBox { | ||||||
|  |   background-color: rgba(0, 0, 0, 0.7); | ||||||
|  |   width: 150px; | ||||||
|  |   height: 100%; | ||||||
|  |   border-top-right-radius: 8px; | ||||||
|  |   border-bottom-right-radius: 8px; | ||||||
|  |   -moz-border-radius-topright: 8px; | ||||||
|  |   -moz-border-radius-bottomright: 8px; | ||||||
|  |   -webkit-border-top-right-radius: 8px; | ||||||
|  |   -webkit-border-bottom-right-radius: 8px; | ||||||
|  |   box-shadow: 0px 2px 8px #000; | ||||||
|  |   -moz-box-shadow: 0px 2px 8px #000; | ||||||
|  |   -webkit-box-shadow: 0px 2px 8px #000; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #sidebarScrollView { | ||||||
|  |   position: absolute; | ||||||
|  |   overflow: hidden; | ||||||
|  |   overflow-y: auto; | ||||||
|  |   top: 10px; | ||||||
|  |   bottom: 10px; | ||||||
|  |   left: 10px; | ||||||
|  |   width: 130px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .thumbnail { | ||||||
|  |   width: 104px; | ||||||
|  |   height: 134px; | ||||||
|  |   background-color: white; | ||||||
|  |   margin: 5px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* === Content view === */ | ||||||
|  | canvas { | ||||||
|  |   margin: auto; | ||||||
|  |   display: block; | ||||||
|  |   box-shadow: 0px 4px 10px #000; | ||||||
|  |   -moz-box-shadow: 0px 4px 10px #000; | ||||||
|  |   -webkit-box-shadow: 0px 4px 10px #000; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .page { | ||||||
|  |   width: 816px; | ||||||
|  |   height: 1056px; | ||||||
|  |   margin: 10px auto; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #viewer { | ||||||
|  |   margin: 44px 0px 0px; | ||||||
|  |   padding: 8px 0px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | |||||||
| @ -12,22 +12,54 @@ | |||||||
|         <script type="text/javascript" src="../glyphlist.js"></script> |         <script type="text/javascript" src="../glyphlist.js"></script> | ||||||
|   </head> |   </head> | ||||||
| 
 | 
 | ||||||
|   <body onload="load();"> |   <body> | ||||||
|     <div id="controls"> |     <div id="controls"> | ||||||
|     <input type="file" style="float: right; margin: auto 32px;" onChange="load(this.value.toString());"></input> |       <button id="previous" onclick="PDFView.page--;"> | ||||||
|     <!-- This only opens supported PDFs from the source path... |         <img src="images/go-up.svg" align="top" height="32"/> | ||||||
|       -- Can we use JSONP to overcome the same-origin restrictions? --> |         Previous | ||||||
|       <button onclick="prevPage();">Previous</button> |       </button> | ||||||
|       <button onclick="nextPage();">Next</button> | 
 | ||||||
|       <input type="text" id="pageNumber" onchange="gotoPage(this.value);" |       <button id="next" onclick="PDFView.page++;"> | ||||||
|              value="1" size="4"></input> |         <img src="images/go-down.svg" align="top" height="32"/> | ||||||
|  |         Next | ||||||
|  |       </button> | ||||||
|  | 
 | ||||||
|  |       <div class="separator"></div> | ||||||
|  | 
 | ||||||
|  |       <input type="text" id="pageNumber" onchange="PDFView.page = this.value;" value="1" size="4"></input> | ||||||
|  | 
 | ||||||
|  |       <span>/</span> | ||||||
|       <span id="numPages">--</span> |       <span id="numPages">--</span> | ||||||
|       <span id="info"></span> | 
 | ||||||
|  |       <div class="separator"></div> | ||||||
|  | 
 | ||||||
|  |       <select id="scaleSelect" onchange="PDFView.scale = parseInt(this.value);"> | ||||||
|  |         <option value="50">50%</option> | ||||||
|  |         <option value="75">75%</option> | ||||||
|  |         <option value="100">100%</option> | ||||||
|  |         <option value="125">125%</option> | ||||||
|  |         <option value="150" selected="selected"><p>150%</p></option> | ||||||
|  |         <option value="200">200%</option> | ||||||
|  |       </select> | ||||||
|  | 
 | ||||||
|  |       <div class="separator"></div> | ||||||
|  | 
 | ||||||
|  |       <input id="fileInput" type="file"></input> | ||||||
|  | 
 | ||||||
|  |       <div class="separator"></div> | ||||||
|  | 
 | ||||||
|  |       <span id="info">--</span> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div id="viewer"> |     <div id="sidebar"> | ||||||
|       <canvas id="canvas"></canvas> |       <div id="sidebarBox"> | ||||||
|  |         <div id="sidebarScrollView"> | ||||||
|  |           <div id="sidebarView"></div> | ||||||
|         </div> |         </div> | ||||||
|  |      </div> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div id="viewer"></div> | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										370
									
								
								web/viewer.js
									
									
									
									
									
								
							
							
						
						
									
										370
									
								
								web/viewer.js
									
									
									
									
									
								
							| @ -3,108 +3,316 @@ | |||||||
| 
 | 
 | ||||||
| 'use strict'; | 'use strict'; | ||||||
| 
 | 
 | ||||||
| var pdfDocument, canvas, pageScale, pageDisplay, pageNum, numPages; | var kDefaultURL = 'compressed.tracemonkey-pldi-09.pdf'; | ||||||
| function load(userInput) { | var kDefaultScale = 150; | ||||||
|   canvas = document.getElementById('canvas'); |  | ||||||
|   canvas.mozOpaque = true; |  | ||||||
|   pageNum = ('page' in queryParams()) ? parseInt(queryParams().page) : 1; |  | ||||||
|   pageScale = ('scale' in queryParams()) ? parseInt(queryParams().scale) : 1.5; |  | ||||||
|   var fileName = userInput; |  | ||||||
|   if (!userInput) { |  | ||||||
|     fileName = queryParams().file || 'compressed.tracemonkey-pldi-09.pdf'; |  | ||||||
|   } |  | ||||||
|   open(fileName); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| function queryParams() { | var kCacheSize = 20; | ||||||
|   var qs = window.location.search.substring(1); |  | ||||||
|   var kvs = qs.split('&'); |  | ||||||
|   var params = { }; |  | ||||||
|   for (var i = 0; i < kvs.length; ++i) { |  | ||||||
|     var kv = kvs[i].split('='); |  | ||||||
|     params[unescape(kv[0])] = unescape(kv[1]); |  | ||||||
|   } |  | ||||||
|   return params; |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| function open(url) { | var Cache = function(size) { | ||||||
|   document.title = url; |   var data = []; | ||||||
|  |   this.push = function(view) { | ||||||
|  |     data.push(view); | ||||||
|  |     if (data.length > size) | ||||||
|  |       data.shift().update(); | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var cache = new Cache(kCacheSize); | ||||||
|  | 
 | ||||||
|  | var PDFView = { | ||||||
|  |   pages: [], | ||||||
|  |   thumbnails: [], | ||||||
|  | 
 | ||||||
|  |   set scale(val) { | ||||||
|  |     var options = document.getElementById('scaleSelect').options; | ||||||
|  |     for (var i = 0; i < options.length; i++) { | ||||||
|  |       var option = options[i]; | ||||||
|  |       option.selected = (option.value == val); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     var pages = this.pages; | ||||||
|  |     var cssUnits = 96.0 / 72.0; | ||||||
|  |     for (var i = 0; i < pages.length; i++) | ||||||
|  |       pages[i].update(val / 100 * cssUnits); | ||||||
|  | 
 | ||||||
|  |     // Jump the scroll position to the correct page.
 | ||||||
|  |     this.page = this.page; | ||||||
|  |   }, | ||||||
|  | 
 | ||||||
|  |   set page(val) { | ||||||
|  |     var pages = this.pages; | ||||||
|  |     var input = document.getElementById("pageNumber"); | ||||||
|  |     if (val <= 0 || val > pages.length) { | ||||||
|  |       input.value = this.page; | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |    | ||||||
|  |     document.location.hash = val; | ||||||
|  |     document.getElementById("previous").disabled = (val == 1); | ||||||
|  |     document.getElementById("next").disabled = (val == pages.length); | ||||||
|  |     if (input.value == val) | ||||||
|  |       return; | ||||||
|  | 
 | ||||||
|  |     input.value = val; | ||||||
|  |     pages[val - 1].draw(); | ||||||
|  |   }, | ||||||
|  | 
 | ||||||
|  |   get page() { | ||||||
|  |     return parseInt(document.location.hash.substring(1)) || 1; | ||||||
|  |   }, | ||||||
|  | 
 | ||||||
|  |   open: function(url, scale) { | ||||||
|     if (url.indexOf("http") == 0) |     if (url.indexOf("http") == 0) | ||||||
|       return; |       return; | ||||||
| 
 | 
 | ||||||
|   var req = new XMLHttpRequest(); |     document.title = url; | ||||||
|   req.open('GET', url); | 
 | ||||||
|   req.mozResponseType = req.responseType = 'arraybuffer'; |     var xhr = new XMLHttpRequest(); | ||||||
|   req.expected = (document.URL.indexOf('file:') == 0) ? 0 : 200; |     xhr.open('GET', url); | ||||||
|   req.onreadystatechange = function() { |     xhr.mozResponseType = xhr.responseType = 'arraybuffer'; | ||||||
|     if (req.readyState == 4 && req.status == req.expected) { |     xhr.expected = (document.URL.indexOf('file:') === 0) ? 0 : 200; | ||||||
|       var data = (req.mozResponseArrayBuffer || req.mozResponse || | 
 | ||||||
|                   req.responseArrayBuffer || req.response); |     xhr.onreadystatechange = function() { | ||||||
|       loadDocument(data); |       if (xhr.readyState === 4 && xhr.status === xhr.expected) { | ||||||
|  |         var data = (xhr.mozResponseArrayBuffer || xhr.mozResponse || | ||||||
|  |                     xhr.responseArrayBuffer || xhr.response); | ||||||
|  | 
 | ||||||
|  |         PDFView.load(data, scale); | ||||||
|       } |       } | ||||||
|     }; |     }; | ||||||
|   req.send(null); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| window.addEventListener("pdfloaded", function(aEvent) { |     xhr.send(null); | ||||||
|   loadDocument(aEvent.detail); |   }, | ||||||
| }, true); |  | ||||||
| 
 | 
 | ||||||
| function loadDocument(data) { |   load: function(data, scale) { | ||||||
|   pdfDocument = new PDFDoc(new Stream(data)); |     var sidebar = document.getElementById('sidebarView'); | ||||||
|   numPages = pdfDocument.numPages; |     sidebar.parentNode.scrollTop = 0; | ||||||
|   document.getElementById('numPages').innerHTML = numPages.toString(); |  | ||||||
|   goToPage(pageNum); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| function gotoPage(num) { |     while (sidebar.hasChildNodes()) | ||||||
|   if (0 <= num && num <= numPages) |       sidebar.removeChild(sidebar.lastChild); | ||||||
|     pageNum = num; |     clearInterval(sidebar._loadingInterval); | ||||||
|   displayPage(pageNum); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| function displayPage(num) { |     var container = document.getElementById('viewer'); | ||||||
|   document.getElementById('pageNumber').value = num; |     while (container.hasChildNodes()) | ||||||
|  |       container.removeChild(container.lastChild); | ||||||
| 
 | 
 | ||||||
|   var t0 = Date.now(); |     var pdf = new PDFDoc(new Stream(data)); | ||||||
|  |     var pagesCount = pdf.numPages; | ||||||
|  |     document.getElementById('numPages').innerHTML = pagesCount; | ||||||
| 
 | 
 | ||||||
|   var page = pdfDocument.getPage(pageNum = num); |     var pages = this.pages = []; | ||||||
|  |     var thumbnails = this.thumbnails = []; | ||||||
|  |     for (var i = 1; i <= pagesCount; i++) { | ||||||
|  |       var page = pdf.getPage(i); | ||||||
|  |       var mediaBox = page.mediaBox; | ||||||
|  |       var width = (mediaBox[2] - mediaBox[0]); | ||||||
|  |       var height = (mediaBox[3] - mediaBox[1]); | ||||||
|  |       pages.push(new PageView(container, page, i, width, height, page.stats)); | ||||||
|  |       thumbnails.push(new ThumbnailView(sidebar, pages[i - 1])); | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|   var pdfToCssUnitsCoef = 96.0 / 72.0; |     this.scale = (scale || kDefaultScale); | ||||||
|   var pageWidth = (page.mediaBox[2] - page.mediaBox[0]); |     this.page = parseInt(document.location.hash.substring(1)) || 1; | ||||||
|   var pageHeight = (page.mediaBox[3] - page.mediaBox[1]); |   }, | ||||||
|   canvas.width = pageScale * pageWidth * pdfToCssUnitsCoef; | 
 | ||||||
|   canvas.height = pageScale * pageHeight * pdfToCssUnitsCoef; |   getVisiblePages: function() { | ||||||
|  |     var pages = this.pages; | ||||||
|  |     var kBottomMargin = 10; | ||||||
|  |     var visiblePages = []; | ||||||
|  | 
 | ||||||
|  |     var currentHeight = kBottomMargin; | ||||||
|  |     var windowTop = window.pageYOffset; | ||||||
|  |     for (var i = 1; i <= pages.length; i++) { | ||||||
|  |       var page = pages[i - 1]; | ||||||
|  |       var pageHeight = page.height * page.scale + kBottomMargin; | ||||||
|  |       if (currentHeight + pageHeight > windowTop) | ||||||
|  |         break; | ||||||
|  | 
 | ||||||
|  |       currentHeight += pageHeight; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     var windowBottom = window.pageYOffset + window.innerHeight; | ||||||
|  |     for (; i <= pages.length && currentHeight < windowBottom; i++) { | ||||||
|  |       var page = pages[i - 1]; | ||||||
|  |       visiblePages.push({ id: page.id, y: currentHeight, view: page }); | ||||||
|  |       currentHeight += page.height * page.scale + kBottomMargin; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return visiblePages; | ||||||
|  |   }, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var PageView = function(container, content, id, width, height, stats) { | ||||||
|  |   this.width = width; | ||||||
|  |   this.height = height; | ||||||
|  |   this.id = id; | ||||||
|  |   this.content = content; | ||||||
|  | 
 | ||||||
|  |   var anchor = document.createElement('a'); | ||||||
|  |   anchor.name = '' + this.id; | ||||||
|  | 
 | ||||||
|  |   var div = document.createElement('div'); | ||||||
|  |   div.id = 'pageContainer' + this.id; | ||||||
|  |   div.className = 'page'; | ||||||
|  | 
 | ||||||
|  |   container.appendChild(anchor); | ||||||
|  |   container.appendChild(div); | ||||||
|  | 
 | ||||||
|  |   this.update = function(scale) { | ||||||
|  |     this.scale = scale || this.scale; | ||||||
|  |     div.style.width =  (this.width * this.scale)+ 'px'; | ||||||
|  |     div.style.height = (this.height * this.scale) + 'px'; | ||||||
|  | 
 | ||||||
|  |     while (div.hasChildNodes()) | ||||||
|  |       div.removeChild(div.lastChild); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   this.draw = function() { | ||||||
|  |     if (div.hasChildNodes()) { | ||||||
|  |       this.updateStats(); | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     var canvas = document.createElement('canvas'); | ||||||
|  |     canvas.id = 'page' + this.id; | ||||||
|  |     canvas.mozOpaque = true; | ||||||
|  | 
 | ||||||
|  |     canvas.width = this.width * this.scale; | ||||||
|  |     canvas.height = this.height * this.scale; | ||||||
|  |     div.appendChild(canvas); | ||||||
| 
 | 
 | ||||||
|   var t1 = Date.now(); |  | ||||||
|     var ctx = canvas.getContext('2d'); |     var ctx = canvas.getContext('2d'); | ||||||
|     ctx.save(); |     ctx.save(); | ||||||
|     ctx.fillStyle = 'rgb(255, 255, 255)'; |     ctx.fillStyle = 'rgb(255, 255, 255)'; | ||||||
|     ctx.fillRect(0, 0, canvas.width, canvas.height); |     ctx.fillRect(0, 0, canvas.width, canvas.height); | ||||||
|     ctx.restore(); |     ctx.restore(); | ||||||
| 
 | 
 | ||||||
|   page.startRendering( |     stats.begin = Date.now(); | ||||||
|     ctx, |     this.content.startRendering(ctx, this.updateStats); | ||||||
|     function() { |  | ||||||
|       var infoDisplay = document.getElementById('info'); |  | ||||||
|       var stats = page.stats; |  | ||||||
|       var t2 = stats.compile, t3 = stats.fonts, t4 = stats.render; |  | ||||||
|       infoDisplay.innerHTML = 'Time to load/compile/fonts/render: ' + |  | ||||||
|         (t1 - t0) + '/' + (t2 - t1) + '/' + (t3 - t2) + '/' + (t4 - t3) + ' ms'; |  | ||||||
|   }); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| function nextPage() { |     return true; | ||||||
|   if (pageNum < pdfDocument.numPages) |   }; | ||||||
|     displayPage(++pageNum); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| function prevPage() { |   this.updateStats = function() { | ||||||
|   if (pageNum > 1) |     var t1 = stats.compile, t2 = stats.fonts, t3 = stats.render; | ||||||
|     displayPage(--pageNum); |     var str = 'Time to compile/fonts/render: ' +  | ||||||
| } |               (t1 - stats.begin) + '/' + (t2 - t1) + '/' + (t3 - t2) + ' ms'; | ||||||
|  |     document.getElementById('info').innerHTML = str; | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var ThumbnailView = function(container, page) { | ||||||
|  |   var anchor = document.createElement('a'); | ||||||
|  |   anchor.href = '#' + page.id; | ||||||
|  | 
 | ||||||
|  |   var div = document.createElement('div'); | ||||||
|  |   div.id = 'thumbnailContainer' + page.id; | ||||||
|  |   div.className = 'thumbnail'; | ||||||
|  | 
 | ||||||
|  |   anchor.appendChild(div); | ||||||
|  |   container.appendChild(anchor); | ||||||
|  | 
 | ||||||
|  |   this.draw = function() { | ||||||
|  |     if (div.hasChildNodes()) | ||||||
|  |       return; | ||||||
|  | 
 | ||||||
|  |     var canvas = document.createElement('canvas'); | ||||||
|  |     canvas.id = 'thumbnail' + page.id; | ||||||
|  |     canvas.mozOpaque = true; | ||||||
|  | 
 | ||||||
|  |     canvas.width = 104; | ||||||
|  |     canvas.height = 134; | ||||||
|  |     div.appendChild(canvas); | ||||||
|  | 
 | ||||||
|  |     var ctx = canvas.getContext('2d'); | ||||||
|  |     ctx.save(); | ||||||
|  |     ctx.fillStyle = 'rgb(255, 255, 255)'; | ||||||
|  |     ctx.fillRect(0, 0, canvas.width, canvas.height); | ||||||
|  |     ctx.restore(); | ||||||
|  | 
 | ||||||
|  |     page.content.startRendering(ctx, function() { }); | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | window.addEventListener('load', function(evt) { | ||||||
|  |   var params = document.location.search.substring(1).split('&'); | ||||||
|  |   for (var i = 0; i < params.length; i++) { | ||||||
|  |     var param = params[i].split('='); | ||||||
|  |     params[unescape(param[0])] = unescape(param[1]); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   PDFView.open(params.file || kDefaultURL, parseInt(params.scale)); | ||||||
|  | 
 | ||||||
|  |   if (!window.File || !window.FileReader || !window.FileList || !window.Blob) | ||||||
|  |     document.getElementById('fileInput').style.display = 'none'; | ||||||
|  |   else | ||||||
|  |     document.getElementById('fileInput').value = null; | ||||||
|  | }, true); | ||||||
|  | 
 | ||||||
|  | window.addEventListener('pdfloaded', function(evt) { | ||||||
|  |   PDFView.load(evt.detail); | ||||||
|  | }, true); | ||||||
|  | 
 | ||||||
|  | window.addEventListener('scroll', function(evt) { | ||||||
|  |   var visiblePages = PDFView.getVisiblePages(); | ||||||
|  |   for (var i = 0; i < visiblePages.length; i++) { | ||||||
|  |     var page = visiblePages[i]; | ||||||
|  |     if (PDFView.pages[page.id - 1].draw()) | ||||||
|  |       cache.push(page.view); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   if (!visiblePages.length) | ||||||
|  |     return; | ||||||
|  | 
 | ||||||
|  |   var currentId = PDFView.page; | ||||||
|  |   var firstPage = visiblePages[0]; | ||||||
|  |   var lastPage = visiblePages[visiblePages.length - 1]; | ||||||
|  |   if (currentId > lastPage.id && lastPage.y > window.pageYOffset) | ||||||
|  |     PDFView.page = lastPage.id; | ||||||
|  |   else if (currentId < firstPage.id) | ||||||
|  |     PDFView.page = firstPage.id; | ||||||
|  | }, true); | ||||||
|  | 
 | ||||||
|  | window.addEventListener("hashchange", function(evt) { | ||||||
|  |   PDFView.page = PDFView.page; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | window.addEventListener("change", function(evt) { | ||||||
|  |   var files = evt.target.files; | ||||||
|  |   if (!files || files.length == 0) | ||||||
|  |     return; | ||||||
|  | 
 | ||||||
|  |   // Read the local file into a Uint8Array.
 | ||||||
|  |   var fileReader = new FileReader(); | ||||||
|  |   fileReader.onload = function(evt) { | ||||||
|  |     var data = evt.target.result; | ||||||
|  |     var buffer = new ArrayBuffer(data.length); | ||||||
|  |     var uint8Array = new Uint8Array(buffer); | ||||||
|  | 
 | ||||||
|  |     for (var i = 0; i < data.length; i++) | ||||||
|  |       uint8Array[i] = data.charCodeAt(i); | ||||||
|  |     PDFView.load(uint8Array); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   // Read as a binary string since "readAsArrayBuffer" is not yet
 | ||||||
|  |   // implemented in Firefox.
 | ||||||
|  |   var file = files[0]; | ||||||
|  |   fileReader.readAsBinaryString(file); | ||||||
|  | 
 | ||||||
|  |   document.title = file.name; | ||||||
|  |   document.location.hash = 1; | ||||||
|  | }, true); | ||||||
|  | 
 | ||||||
|  | window.addEventListener("transitionend", function(evt) { | ||||||
|  |   var pageIndex = 0; | ||||||
|  |   var pagesCount = PDFView.pages.length; | ||||||
|  | 
 | ||||||
|  |   var container = document.getElementById('sidebarView'); | ||||||
|  |   container._interval = window.setInterval(function() { | ||||||
|  |     if (pageIndex >= pagesCount) | ||||||
|  |       return window.clearInterval(container._interval); | ||||||
|  |          | ||||||
|  |     PDFView.thumbnails[pageIndex++].draw(); | ||||||
|  |   }, 500); | ||||||
|  | }, true); | ||||||
| 
 | 
 | ||||||
| function goToPage(num) { |  | ||||||
|   if (0 <= num && num <= numPages) |  | ||||||
|     displayPage(pageNum = num); |  | ||||||
| } |  | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user