-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Open files from File Picker & small improvements (#7)
* Open files from File Picker & small improvements - Open files directly from the system's File Picker if the PWA is installed - Improved the UI in the Settings, using a new "Sections" element for differentiating between tabs - Improved documentation, by using /** */ for some objects/functions instead of // - Switched some "let" to "const" * Update the README with the new React app
- Loading branch information
1 parent
da04909
commit 2304a9e
Showing
50 changed files
with
1,028 additions
and
415 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,75 +1,190 @@ | ||
# pdf-pointer | ||
Display PDFs with a pointer, make quick annotations (that automatically disappear), and zoom them | ||
|
||
Try it: https://dinoosauro.github.io/pdf-pointer/ | ||
Display PDFs with a pointer, make quick annotations (that automatically | ||
disappear), zoom them, and export everything as an image Try it: | ||
https://dinoosauro.github.io/pdf-pointer/ | ||
|
||
data:image/s3,"s3://crabby-images/e7646/e7646d1b377dd124ae07a5e7cb265205e1591085" alt="An example of PDFPointer" | ||
|
||
## Open a file | ||
data:image/s3,"s3://crabby-images/46b5e/46b5eda8e87fb5fbbc50286f78516bb2c1ed9383" alt="The welcome screen of PDFPointer" | ||
When you open the webpage, you'll be asked to open a file. Select a PDF and PDFPointer will automatically display it. You can also drag and drop the file. | ||
|
||
At the right, you can see that it's possible to install the app for offline use. See the "Offline Use" section of this README for more information. | ||
## Functions | ||
You can access to all of the functions from the toolbar. | ||
data:image/s3,"s3://crabby-images/cbf60/cbf6018fbf22c0a901a6ea3db2455596f3380167" alt="A screenshot of the toolbar options in PDFPointer" | ||
|
||
### Draw into a PDF | ||
With PDFPointer, you can create quick annotations that disappear automatically. To do that, click the pen icon from the tools above. Start drawing, and, by default, the annotations will disappear after 15 seconds. If you want to change it, click on the Timer icon and then choosse another option. If you want to erase sooner the drawing, click on the eraser icon. You can also change the color of the drawing tool clicking the _color_ icon next to the erase one. | ||
data:image/s3,"s3://crabby-images/b9b40/b9b403d5c20073cca1404a8f48fdc6bcbfe52897" alt="A screenshot of a PDF opened in PDFPointer" | ||
### Fullscreen | ||
Click on the fullscreen icon (the one after the color one) and the document will be displayed in full screen. The bar will automatically move to the left of the screen. | ||
data:image/s3,"s3://crabby-images/f9ae7/f9ae74edc82efa17dd2f0e32ff4745d83aafcfb3" alt="An image showing PDFPointer in full screen" | ||
### Save as image | ||
You can download your PDF with annotations as a JPG/PNG/WebP image by clicking the save image button. You'll be asked the pages to export, the image resolution and its quality (for lossy compression formats). PDFPointer will then export them. | ||
|
||
You can also export them in a .zip file. This can be useful if your PDF has lots of pages. | ||
|
||
### From the website | ||
|
||
When you open the website, you'll be prompted to open a website. Click on the | ||
button and select one of it. | ||
|
||
data:image/s3,"s3://crabby-images/6fd44/6fd4499a437e72d5151f5ff5c6d3784205edfe6f" alt="The UI of the "File picker" page" | ||
|
||
### From the file picker | ||
|
||
If you've installed PDFPointer as a Progressive Web App, you can open PDF files | ||
directly from your device's file picker. Right-click the file you want to open, | ||
and select "PDFPointer" from the "Open with" menu. You _could_ also make | ||
PDFPointer the default application for opening PDF files, but honestly neither I | ||
would do that. | ||
|
||
## Functionaly | ||
|
||
You can access to all functionalities of PDFPointer from the Toolbar | ||
data:image/s3,"s3://crabby-images/54ff9/54ff9e897da01e9f04f973f68835592bfbba8fad" alt="The toolbar" | ||
|
||
### Previous and next page | ||
|
||
The first and the last button permit to change the page. Simple as that. | ||
|
||
### Zoom in and out | ||
|
||
These buttons permits to change the zoom size. Currently, zoom is | ||
increased/decreased by 0.2 | ||
|
||
### Show thumbnails | ||
|
||
PDFs can have lots of pages. To quickly navigate them, click on the "Show | ||
thumbnails" button to show a preview of each page. Click on each preview to | ||
change page. | ||
|
||
### Pen | ||
|
||
Create a pen annotation. By clicking it, the pen controls will be shown: | ||
|
||
data:image/s3,"s3://crabby-images/747b9/747b9e76ffe24eb52cfb962590ed8c827d6b309d" alt="Pen toolbar" | ||
|
||
2. Change the annotation timer | ||
3. Change the size of the annotation | ||
4. Change the opacity of the annotation | ||
5. Change the color of the annotation | ||
6. Enable eraser | ||
|
||
### Pointer | ||
|
||
Change settings about the pointer. By clicking it, the pointer controls will be | ||
shown: | ||
|
||
data:image/s3,"s3://crabby-images/e9409/e9409ad66db125139ed1d2f62e5b329920adc8e1" alt="Pointer toolbar" | ||
|
||
2. Change pointer color | ||
3. Change pointer size | ||
|
||
### Eraser | ||
|
||
Erase both text and pen annotations, by pressing on the part of the canvas to | ||
delete. | ||
|
||
### Text | ||
|
||
Write text on the PDF. By clicking it, the text controls will be shown: | ||
|
||
data:image/s3,"s3://crabby-images/0ef66/0ef66c73f76dbe2e06f47c00e4f92ddb76196bfa" alt="Text toolbar" | ||
|
||
2. Change the text delete timer | ||
3. Change text size | ||
4. Change text color | ||
5. Change text font family | ||
6. Enable/disable bold text | ||
7. Enable/disable italic text | ||
8. Enable/disable underlined text | ||
9. Enable/disable striked text | ||
10. Change underlined/striked bar height | ||
11. Change line spacing | ||
12. Enable eraser mode | ||
|
||
### Fullscreen mode | ||
|
||
Enable fullscreen mode. If zooms weren't made, the PDF will be adapted to the | ||
screen'size. Otherwise, the zoom size will be adapted to the screen's size | ||
compared to the default (PDF scale) | ||
|
||
### PDF Filters | ||
|
||
You can add some filters to the PDF to made it easier to read at night. The | ||
filters, adjustable with a slider, are: | ||
|
||
- Negative | ||
- Hue inversion | ||
- Sepia | ||
- Grayscale | ||
|
||
### Export PDF as image | ||
|
||
You can also export the PDF as an array of images. In the new exportation | ||
dropdown, you can specify the number of page to export, the format (and the | ||
quality for lossy formats) and the output screen size. | ||
|
||
It's also possible to export all the annotations, applying also the current PDF | ||
filters. | ||
|
||
If selected, the PDF images will be exported in a PDF file. Otherwise, if the | ||
browser supports it, the File System API will be used to get direct access to | ||
the output folder, otherwise file will be downloaded as Blob links. | ||
|
||
data:image/s3,"s3://crabby-images/61165/61165c0ca5220f3ee4d2a18834c443c0a36cca9c" alt="PDF Export dialog" | ||
|
||
### Settings | ||
In the settings, you can change lots of things: | ||
- Delete/Add custom colors | ||
- Choose if alerts should be shown (and their length) | ||
- Change the color of the pointer | ||
- [Change, delete or create an application theme](https://github.com/Dinoosauro/pdf-pointer/tree/main/themeCreator) | ||
- Change the zoom option between zooming the PDF canvas or scrolling it; kepp annotations when zooming and enable a button to expand the PDF canvas size. | ||
- Change the background color/image/video of the application. | ||
- Change the language of the application | ||
- See keyboard shortcuts | ||
- See the licenses of the open source libraries | ||
### Zoom in/out | ||
You can zoom the PDF by clicking the magnifying glass icon. | ||
### Expand and contract PDF | ||
Those two strange symbols before the "Next page" one and after the "Previous page" one arte he expand and contract button. These can optionally be enabled by the settings, and allow the user to control in a greater way than zooming the dimension of the canvas where the PDF is displayed. You can use them in both zoom modes. | ||
### Next/Previous page | ||
Click the next/previous icon to go to the next/previous page. | ||
|
||
## Offline use | ||
You can use PDFPointer offline by installing the website as a Progressive Web App (currently supported only on Chromium). Make sure to be online the first time and to open a PDF, then everything should work just fine. | ||
## Keyboard shortcuts | ||
The following keyboard shortcuts are supported: | ||
| Key | What it does | | ||
| --- | ---- | | ||
| ⇧ (Shift) | Start (or finish) an annotation | | ||
| ⌥/Alt (Option) | Force stop an annotation | | ||
| ⌫ (Backspace) | Delete an annotation | | ||
| ▶ (Right arrow) | Next page | | ||
| ◀ (Left arrow) | Previous page | | ||
| + (Plus sign) | Increase zoom | | ||
| - (Minus sign) | Decrease zoom | | ||
|
||
You can see them also from the website's settings. | ||
|
||
## Change background image/video | ||
|
||
You can change the background with a local image, the default background color and YouTube videos. Yes, this means you can keep those Minecraft parkour backgrounds also when reading PDF. | ||
|
||
data:image/s3,"s3://crabby-images/174bc/174bc42c55e1c7d527c1b7418536297e9fc35eca" alt="An image showing Minecraft parkour in the background while displaying a PDF." | ||
|
||
*The industrial revolution and its consequences...* | ||
|
||
Open the settings dialog. | ||
|
||
## Privacy | ||
Your PDF files are never uplaoded to the cloud. Everything is elaborated locally on your device. | ||
## Settings | ||
|
||
PDFPointer permits to change basically everything about its usage. In the | ||
settings, you can edit: | ||
|
||
### Custom color | ||
|
||
The new custom colors will appear in the "Fill" dropdowns for pen/text/pointer | ||
colors. | ||
|
||
data:image/s3,"s3://crabby-images/d51ba/d51ba7a4adc6e3805a8dfeea7b75b8f25b8781d2" alt="Custom color tab" | ||
|
||
### Custom theme | ||
|
||
Manage, apply, create or delete themes. | ||
|
||
You can edit each color by clicking on the respective color. Scroll to the right | ||
to see every value, and, at the end of this list, you'll find a button to save | ||
the theme. There are basically no limits to the number of themes you can have. | ||
|
||
_Actually, there are: 10^16 themes, or 5MB in the LocalStorage (including other | ||
settings)_ | ||
|
||
PDFPointer connects to the following domains: | ||
data:image/s3,"s3://crabby-images/60e8f/60e8f55e1ef97c0ff2cf8a0635b4a87a7287dc33" alt="Custom themes tab" | ||
|
||
### Alerts | ||
|
||
Alerts are some text information that appear at the top of the screen. You can | ||
choose to disable them completely, or to hide only some of them. You can also | ||
change the length they are visible. | ||
|
||
data:image/s3,"s3://crabby-images/4756c/4756cb1804026be4a95f7547f8ab4f2d492d37a7" alt="Alerts tab" | ||
|
||
### Language | ||
|
||
Change the language used by PDFPointer. Currently, only Italian and English are | ||
supported. | ||
|
||
data:image/s3,"s3://crabby-images/e28b6/e28b6e52b0ded2ff7f6428166f03c77dc35e752b" alt="Language tab" | ||
|
||
### Background content | ||
|
||
You can customize the backgroud content by putting a classic color, an image or | ||
a video (both from local files and from YouTube). | ||
|
||
data:image/s3,"s3://crabby-images/7dbab/7dbab5ab80c6b977fcfa15d269d47ca23254fe20" alt="Background content tab" | ||
|
||
_An example of the UI with a custom background can be found at the top of this | ||
README_ | ||
|
||
### Licenses | ||
|
||
Show open source licenses | ||
|
||
## Progressive Web App | ||
|
||
You can install PDFPointer as a Progressive Web App for a better experience. | ||
You'll also be able to open PDF files directly from the file picker, and you'll | ||
be able to use the website completely offline. | ||
|
||
## Privacy | ||
|
||
- Google Fonts: to download the fonts used for the text, no data is shared with Google | ||
- JSDelivr/GitHub/CloudFlare: download libraries that make the software work | ||
- GitHub Pages: hosting of pdf-pointer | ||
- YouTube: only if you enable YouTube videos as a background from Settings | ||
Your PDFs stays always on your device. The only external connections made by | ||
PDFPointer are to Google Fonts' servers (and YouTube if you enable a YouTube | ||
video for background content), but no data is shared with them. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,16 +1,24 @@ | ||
{ | ||
"name": "PDFPointer", | ||
"short_name": "PDFPointer", | ||
"start_url": "index.html", | ||
"display": "standalone", | ||
"background_color": "#151515", | ||
"theme_color": "#2c8b9b", | ||
"orientation": "landscape-primary", | ||
"icons": [ | ||
{ | ||
"src": "./icon.png", | ||
"type": "image/png", | ||
"sizes": "512x512" | ||
} | ||
] | ||
} | ||
"name": "PDFPointer", | ||
"short_name": "PDFPointer", | ||
"start_url": "index.html", | ||
"display": "standalone", | ||
"background_color": "#151515", | ||
"theme_color": "#2c8b9b", | ||
"orientation": "landscape-primary", | ||
"icons": [ | ||
{ | ||
"src": "./icon.png", | ||
"type": "image/png", | ||
"sizes": "512x512" | ||
} | ||
], | ||
"file_handlers": [ | ||
{ | ||
"action": "./", | ||
"accept": { | ||
"application/pdf": [".pdf"] | ||
} | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
2.0.0 | ||
2.0.1 |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.