Reputation: 31
In my app users can create new pages for a PDF by adding them as objects to an ArrayList. The new page creation is then managed by a for loop to iterate through each object in the ArrayList and print it to a new page.
But when I open the PDF that has been created I seem to be getting a 'squared' amount of pages. e.g I create 2 pages, I get 4 I create 3 pages, I get 9 etc
I think it has something to do with my for loop but I can't see it. Can someone have a look at my code?
public class MainActivity extends AppCompatActivity {
private EditText firstEditText;
ArrayList<PDFPageModel> pageModelArrayList = new ArrayList<>();
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
firstEditText = findViewById(R.id.firstEditText);
//request permissions (I won't need this part)
ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE}, PackageManager.PERMISSION_GRANTED);
//clear array memory each time you onCreate
pageModelArrayList.clear();
}
public void addObjectToList(View view){
//create new object
PDFPageModel pdfPageModel = new PDFPageModel();
//add stuff to object from edit text and set type
pdfPageModel.setPageData(firstEditText.getText().toString().trim());
pdfPageModel.setType("Text");
pageModelArrayList.add(pdfPageModel);
Toast.makeText(MainActivity.this, "Text added", Toast.LENGTH_LONG).show();
}
@RequiresApi(api = Build.VERSION_CODES.KITKAT)
public void createMyPDF(View view){
//done in 3 parts
//1. creation of PDF document, 2. writing to the document, 3. save document to folder
//1. PDF Document Creation
PdfDocument pdfDocument = new PdfDocument();
//2.
//for loop for ArrayList new page
for (int i=0; i < pageModelArrayList.size(); i++){
for(PDFPageModel filledData : pageModelArrayList){
filledData.getPageData();
filledData.getType();
if(filledData.getType() == "Text"){
//create a page info description
PdfDocument.PageInfo pageInfo = new PdfDocument.PageInfo.Builder(595, 842, i+1).create();
//start a page
PdfDocument.Page page = pdfDocument.startPage(pageInfo);
//writing to new page
Paint paint = new Paint();
//canvas used to write to page, getting object data from inputted text
String myString = filledData.getPageData();
//setting where to start text on the page
int x = 10, y = 25;
//multi line loop
for(String line:myString.split("\n")){
page.getCanvas().drawText(line, x, y, paint);
y+=paint.descent()-paint.ascent();
}
//finish page
pdfDocument.finishPage(page);
}else {
Toast.makeText(MainActivity.this, "Object Type not text", Toast.LENGTH_LONG).show();
}
}
}
//3. saving to folder
String myFilePath = String.valueOf(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS));
String fileName = "/myNewPDF-TEST.pdf";
//create folder to be saved in
File myFile = new File(myFilePath + "/PDFTestStorage");
if(!myFile.exists()){
myFile.mkdirs();
}
//new file
File file = new File(myFile, fileName);
//save document
try {
pdfDocument.writeTo(new FileOutputStream(file));
Toast.makeText(MainActivity.this, "File Created", Toast.LENGTH_LONG).show();
} catch (Exception e) {
e.printStackTrace();
Toast.makeText(MainActivity.this, "Error: File not created", Toast.LENGTH_LONG).show();
}
//close pdf doc
pdfDocument.close();
}
Upvotes: 1
Views: 502
Reputation: 58
Simply removing the outermost for loop, i.e replacing:
for (int i=0; i < pageModelArrayList.size(); i++){
for(PDFPageModel filledData : pageModelArrayList){
filledData.getPageData();
filledData.getType();
if(filledData.getType() == "Text"){
//create a page info description
PdfDocument.PageInfo pageInfo = new PdfDocument.PageInfo.Builder(595, 842, i+1).create();
//start a page
PdfDocument.Page page = pdfDocument.startPage(pageInfo);
//writing to new page
Paint paint = new Paint();
//canvas used to write to page, getting object data from inputted text
String myString = filledData.getPageData();
//setting where to start text on the page
int x = 10, y = 25;
//multi line loop
for(String line:myString.split("\n")){
page.getCanvas().drawText(line, x, y, paint);
y+=paint.descent()-paint.ascent();
}
//finish page
pdfDocument.finishPage(page);
}else {
Toast.makeText(MainActivity.this, "Object Type not text", Toast.LENGTH_LONG).show();
}
}
}
with:
int i=0;
for(PDFPageModel filledData : pageModelArrayList){
filledData.getPageData();
filledData.getType();
if(filledData.getType() == "Text"){
//create a page info description
PdfDocument.PageInfo pageInfo = new PdfDocument.PageInfo.Builder(595, 842, i+1).create();
//start a page
PdfDocument.Page page = pdfDocument.startPage(pageInfo);
//writing to new page
Paint paint = new Paint();
//canvas used to write to page, getting object data from inputted text
String myString = filledData.getPageData();
//setting where to start text on the page
int x = 10, y = 25;
//multi line loop
for(String line:myString.split("\n")){
page.getCanvas().drawText(line, x, y, paint);
y+=paint.descent()-paint.ascent();
}
//finish page
pdfDocument.finishPage(page);
}else {
Toast.makeText(MainActivity.this, "Object Type not text", Toast.LENGTH_LONG).show();
i++
}
Should get you one step closer to solving the issue. The squared behaviour you're describing almost certainly comes from nested loops.
Upvotes: 1