summaryrefslogtreecommitdiff
path: root/android/src/com/artifex
AgeCommit message (Collapse)Author
2013-02-26Android: add support for highlight and underline markup annotations.Paul Gardiner
Highlight annotations currently come out opaque so aren't a lot of use.
2013-02-26Include required quadPoints entry in created markup annotations.Paul Gardiner
Also change the way we pass the text rectangles so that non-axis-aligned ones can be permitted, and relocate the code that calculates the strike-out lines from the bounding boxes
2013-02-26Android: implement annotation deletionPaul Gardiner
2013-02-22Android: add annotation-editing menu, triggered on annotation selectionPaul Gardiner
2013-02-22Android: support selection of annotationPaul Gardiner
2013-02-22Android: move selected text operations from PageView to MuPDFPageViewPaul Gardiner
2013-02-22Android: avoid unnecessary repeated set up of child viewsPaul Gardiner
This change showed up a bug where highlights may fail to show if passed in while the page was set as blank. That bug is also fixed in this commit
2013-02-22Android: add MuPDFCore.getAnnotationsPaul Gardiner
2013-02-13Android: highlight reflow icon when in reflow modePaul Gardiner
2013-02-11Android: factor out ReaderView's special handling of MuPDFView objectsPaul Gardiner
2013-02-11Android: factor out search from main activityPaul Gardiner
2013-02-05Android: reflow - request layout each time we learn a new page heightPaul Gardiner
2013-02-05Android: Avoid SEGV on reflow on HTC Desire HDRobin Watts
Move the one time setup of the HTMLOUT javascript interface etc into the constructor. This seems to avoid the occasional SEGV caused while flipping pages on the HTC Desire in reflow mode.
2013-02-05Android: avoid view churn in reflow modePaul Gardiner
2013-02-05Android: reflow - get zoom working againPaul Gardiner
2013-02-05Android: avoid byte[] -> String -> byte[]Paul Gardiner
2013-02-05Android: Use HTML output in reflow mode.Robin Watts
This gets us styles.
2013-02-04Android: reset zoom on mode changePaul Gardiner
We should probably record the last scale for each mode and reenstate it when returning to that mode, but there are a few difficulties to that that need to be addressed
2013-02-04Android: alter zoom range for reflow modePaul Gardiner
2013-02-04Android: zooming in reflow mode altering CSS fontSize via javascriptPaul Gardiner
2013-02-04Android: add hooks for zooming in reflow modePaul Gardiner
2013-02-04Android: add button for reflowPaul Gardiner
2013-02-04Android: handle Unicode correctly in reflowPaul Gardiner
2013-02-03Android: first attempt at reflow modePaul Gardiner
2013-02-02Android: introduce common interface for normal and reflowed viewsPaul Gardiner
2013-02-01Android: quick and dirty conversion of text to htmlPaul Gardiner
2013-01-31Android: implement strikeout annotation creationPaul Gardiner
2013-01-26Android: Fix NullPointerException seen on Google PlayRobin Watts
According to Google Plays automated crash detection, we get a NullPointerException when trying to parse a null string as a Uri. This turns out to be caused by us trying to open a PDF attachment from gmail. This is because MuPDF is invoked with a content:// URL that does not have a file associated with it. Instead we can open that URL as an InputStream. Here we amend MuPDF to spot that case, and to open the InputStream, suck the data into a byteArray, and then to use that to open the file from.
2013-01-25Android: Refine Smart Motion to avoid tiny scrolls at end of pagesRobin Watts
Tor observes that when advancing down a page, it's annoying to have a tiny scroll at the end to expose the last pixel. To avoid this, he suggests making the amount we scroll dynamic; rather than always moving by 90% of the screen height, we allow ourselves to move between 80% and 95% of the screen height if it means that we'll exactly meet the end of the page. This seems to work well.
2013-01-24Android: Smart Motion fix.Robin Watts
Moving backwards from the top of a zoomed out page was taking us back to the top of the previous page, not the bottom. Fixed here. Thanks to Tor for spotting this.
2013-01-24android: Tint the icon in the file picker.Tor Andersson
Use setImageResource instead of setBackgroundResource!
2013-01-24Android: Show path in file picker title.Robin Watts
Also, replace ".." with "[Up one level]".
2013-01-24Android: Implement 'Smart Motion'.Robin Watts
Currently, when the edges of the screen are tapped, we move just enough to bring the next/previous page onto the screen. When we are zoomed out, this is exactly what we want. When we are zoomed in, however, it rarely is, as 1) it doesn't allow for their being more content on the same page that we might want to view, and 2) it doesn't take us the the same region of the next page, but rather to the 'nearest edge' of the next page at the same zoom. This is particularly annoying as if we accidentally hit 'right', we can't then hit 'left' to go back to where we were. Smart Motion is an attempt to more neatly advance/retreat through the document in a logical fashion. When we are asked to 'advance', we try to advance down the page by 90% of the screen height; this will bring the next pageful of information into view, allowing for lines that might have been split over the edge of the screen before. If that would take us past the bottom of the page, we just move to the bottom of the page. If we are already at the bottom of the page, however, we consider advancing to the next 'column' of content on this page (i.e. we look to see if we have another screenful of content to the right of this one). If we do, we move to the top of the same page, at the top. If we don't, we move to the next page. When we move to the next page, we always move to the top, but our X position is chosen to match the first column of text (as calculated from the current screen position) on the next page. We assign the right hand side and bottom edges of the screen to 'advance', and the left and top edges to 'retreat'. Common use cases: * When the screen is zoomed out, left/right act precisely as they always have. * When the screen is zoomed in to avoid the margins of the page, left/right jump to the next/previous pages, with the same zoom, an improvement on the current mechanism. * When the screen is zoomed in to view a portrait file in landscape mode so that a line of text just fills the screen, left/right move nicely down the page a screenful at a time, and advances to do the same on the next page. We had no way of doing this before. * When the page is in 2 (or more) columns, and the user zooms to fit a single column in, advance nicely follows the flow across multiple pages. We had no way to do this before.
2013-01-22Android: Fix clipboard operation on older androids.Robin Watts
ClipboardManager changed its API at Honeycomb, AnimatorInflater only appeared at Honeycomb. Both of these are used by the clipboard code. Add fallback code to work with the older systems on older devices.
2013-01-22Android: Make the 'tap to skip page' regions more smartly sized.Robin Watts
Rather than always using 20% of the screen for the tap region (which can be excessive and confusing on a large tablet), instead try to use just the left/right inch. We do this by reading the dpi of the screen. As (apparently) some devices lie about the dpi of the screen we arrange first to always use at least 100 pixels, and then never to use more than 1/5 of the screen.
2013-01-22More work on android bitmap recycling.Robin Watts
After much discussion and investigation, Paul and I have realised that we do in fact (in the current scheme at least) need to hold the existing bitmap in memory while drawing the next one (as the existing bitmap is still in an ImageView and being used for any foreground render requests). As such remove a 'setBm(null)' in drawPage. Also, in the onPostExecute for the patch redraw, we cannot recycle the bitmap in a bitmap holder due to it still potentially being in use. We therefore add a 'drop' method to the BitmapHolder class that sets the reference to null without recycling. This is not ideal, but is better than recycling too early and causing crashes.
2013-01-21Rename app.Robin Watts
Due to a clash on Google Play, we need to rename the apps main class from com.artifex.mupdf to something else. We choose com.artifex.mupdfdemo. Any user of the code in their own app should rename it similarly. To simplify this process we add some macros in the C. Various renames and lots of tedious package name editing is still required in the Java though.
2013-01-21Android: fix crashes due to attempts to draw recycled bitmapsPaul Gardiner
Move BitmapHolder setBm call to the main thread and after the ImageView's setImageBitmap call.
2013-01-21Android: fix intermittent loss of HQ render after searchPaul Gardiner
2013-01-11Bug 693547: Android external hyperlink supportRobin Watts
Paul had written code before to detect clicks on hyperlinks, but we hadn't actually done anything with these clicks once detected. Andre Ferreira supplied a couple of lines of Android magic to form the Intent from the URL and execute it. Incorporate that here. (Andre should have é but this upsets git/my editor, sorry) As part of this patch, we now respond to links at a higher priority than the left/right clicks to flip pages (but only if link following mode is enabled).
2013-01-11Bug 693546: Improve Bitmap recycling in Android app.Robin Watts
Thanks to Andre Ferreira for bringing this up and submitting a patch. (Andre should have &eacute, but this upsets git/my editor, sorry!) Change BitmapHolder handling so that we explicitly recycle bitmaps. Old versions of Android need this to avoid bitmaps 'sticking' in memory, and it doesn't hurt on new versions. Also, explicitly empty the bitmap holder before creating a new bitmap. This avoids us holding more than one copy of the (potentially large) bitmaps.
2013-01-11Android: implement copying of selected text to clipboardPaul Gardiner
2013-01-10Android: implement text selection in separate class for future reusePaul Gardiner
Also invalidate search view on every select box change and avoid creating multiple get-text tasks
2013-01-10Android: add text selectionPaul Gardiner
although not actually do anything with the selection yet
2013-01-10Android: add core method returning the words on a pagePaul Gardiner
2012-12-19Android: maintain the scroll position within the file picker between viewsPaul Gardiner
Also removed the split between onCreate and onResume. No idea why I introduced that in the first place.
2012-12-18Android: avoid null exceptions when visiting protected directoriesPaul Gardiner
2012-12-18Android: add directory navigation to the file pickerPaul Gardiner
2012-12-13Android: add hooks to the app to handle GoToR linksPaul Gardiner
2012-12-05Android: fix opening the wrong document from the file pickerPaul Gardiner
Sort the file list rather than the list adapter, so that the onclick position can validly be used to index the file list