Simple library to generate and view PDF in Android
PDFCreatorAndroid
Simple library to generate and view PDF in Android.
A simple library to create and view PDF with zero dependency Or native code.
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Step 2. Add the dependency
dependencies {
implementation 'com.github.tejpratap46:PDFCreatorAndroid:1.0'
}
Try It
Concept
- Android has capability to print documents to PDF, this library simplifies those API's to generate PDF easily.
- At basic level, API renders Views to PDF. To create A PDF with pages we need to submit views exactly height of one page, any view larges then that that will be trimmed.
- This library creates pages by adding views to a parent view unitil the next view is about to exceed current page. If next view exceeds current page, that view will be added to new page.
Implementation
- First thing first, Look at MainActivity of app.
- PDF creater uses views which can be rendered, So we need to exted an activity in order to create activity.
- Create a Empty
Activity
without any layout and extend it withPDFCreatorActivity
. Do not set usesetContentView(int resourceId)
inside your created activity. - There are 3 abstract methods you have to override.
getHeaderView()
- This will be header for PDF and will be added to each page. (Use PDFHeaderView if )
getBodyViews()
- This will return a PDFBody which consist of list of views which can be broken between pages.
onNextClicked()
- This is a handler method to get callback when user taps on Next.
- In
onCreate
of you activity, you have to callcreatePDF(String fileName, PDFUtilListener listener)
. It will generate PDF and give you a PDF file in callback (if success). After receiving callback you can close activity and do whatever you need to do with PDF. - This library also provides
PDFUtil.pdfToBitmap(File pdfFile)
method to get image preview of all pages of sepcified PDF file.
Available Views
TextView
->PDFTextView
VerticalView
->PDFVerticalView
HorizontalView
->PDFHorizontalView
ImageView
->PDFImageView
TableView
->PDFTableView
Saperator
->PDFLineSaperatorView
Advanced
If you cannot find some methods of a View
Class inside PDFView
class you can get view by calling pdfView.getView()
on any available PDFView class and then update view properties.
For example Android TextView
support setting html to TextView which is not available in PDFTextView
, to do that see example below:
PDFTextView pdfIconLicenseView = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.H3);
Spanned icon8Link = Html.fromHtml("Icon from <a href='https://icons8.com'>https://icons8.com</a>");
pdfIconLicenseView.getView().setText(icon8Link);
Another example, Set gravity to View
pdfIconLicenseView.getView().setGravity(Gravity.CENTER_VERTICAL);
Advanced, Proceed with caution :warning:
This is a unfinished feature, Use only for basic cases [After using this feature you cannot add child view to your custom view].
If you want to add a custom view to PDF (such as chart or icon), you just can create your own like this:
PDFVerticalView verticalView = new PDFVerticalView(context);
verticalView.setView(View view);
Example:
An example is created, Look at MainActivity of app.
VIEWS
- PDFVerticalView
PDFVerticalView verticalView = new PDFVerticalView(getApplicationContext());
PDFTextView pdfTextView1 = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setText("TextView1");
verticalView.addView(pdfTextView1)
PDFTextView pdfTextView2 = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setText("TextView2");
verticalView.addView(pdfTextView2)
// Get View
LinearLayout layout = verticalView.getView();
- PDFHorizontalView
PDFHorizontalView horizontalView = new PDFHorizontalView(getApplicationContext());
PDFTextView pdfTextView1 = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setText("TextView1");
horizontalView.addView(pdfTextView1)
PDFTextView pdfTextView2 = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setText("TextView2");
horizontalView.addView(pdfTextView2)
// Get View
LinearLayout layout = horizontalView.getView();
- PDFTextView
PDFTextView pdfTextView1 = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setText("TextView1");
PDFTextView pdfTextView2 = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setText(new SpanningString("TextView2"));
// Get View
TextView textView = pdfTextView2.getView();
- PDFImageView
PDFImageView pdfImageView = new PDFImageView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P)
.setImageResource(R.drawable.ic_example);
// Get View
ImageView imageView = pdfImageView.getView();
- PDFTableView
String[] textInTable = {"1", "2", "3", "4"};
// Create table column headers
PDFTableView.PDFTableRowView tableHeader = new PDFTableView.PDFTableRowView(getApplicationContext());
for (String s : textInTable) {
PDFTextView pdfTextView = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P);
pdfTextView.setText("Header Title: " + s);
tableHeader.addToRow(pdfTextView);
}
// Create first row
PDFTableView.PDFTableRowView tableRowView1 = new PDFTableView.PDFTableRowView(getApplicationContext());
for (String s : textInTable) {
PDFTextView pdfTextView = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P);
pdfTextView.setText("Row 1 : " + s);
tableRowView1.addToRow(pdfTextView);
}
// PDFTableView takes table header and first row at once because if page ends after adding header then first row will be on next page. To avoid confusion to user, table header and first row is printed together.
PDFTableView tableView = new PDFTableView(getApplicationContext(), tableHeader, tableRowView1);
for (int i = 0; i < 10; i++) {
// Create 10 rows and add to table.
PDFTableView.PDFTableRowView tableRowView = new PDFTableView.PDFTableRowView(getApplicationContext());
for (String s : textInTable) {
PDFTextView pdfTextView = new PDFTextView(getApplicationContext(), PDFTextView.PDF_TEXT_SIZE.P);
pdfTextView.setText("Row " + (i + 1) + ": " + s);
tableRowView.addToRow(pdfTextView);
}
tableView.addRow(tableRowView);
}
- PDFLineSeparatorView
PDFLineSeparatorView lineSeparatorWhite = new PDFLineSeparatorView(getApplicationContext()).setBackgroundColor(Color.WHITE);
PDFLineSeparatorView lineSeparatorBlack = new PDFLineSeparatorView(getApplicationContext()).setBackgroundColor(Color.BLACK);
// Get View
View separatorView = lineSeparatorWhite.getView();