mirror of
https://github.com/geometer/FBReaderJ.git
synced 2025-10-04 02:09:35 +02:00
updated API
This commit is contained in:
parent
3ea71a1efc
commit
d2dfafccf8
5 changed files with 93 additions and 17 deletions
|
@ -20,24 +20,30 @@
|
||||||
package org.geometerplus.android.fbreader.api;
|
package org.geometerplus.android.fbreader.api;
|
||||||
|
|
||||||
public interface Api {
|
public interface Api {
|
||||||
public void connect();
|
void connect();
|
||||||
public void disconnect();
|
void disconnect();
|
||||||
|
|
||||||
// fbreader information
|
// fbreader information
|
||||||
public String getFBReaderVersion() throws ApiException;
|
String getFBReaderVersion() throws ApiException;
|
||||||
|
|
||||||
// book information
|
// book information
|
||||||
public String getBookLanguage() throws ApiException;
|
String getBookLanguage() throws ApiException;
|
||||||
|
String getBookTitle() throws ApiException;
|
||||||
|
//String getBookAuthors() throws ApiException;
|
||||||
|
//String getBookTags() throws ApiException;
|
||||||
|
String getBookFileName() throws ApiException;
|
||||||
|
|
||||||
// text information
|
// text information
|
||||||
public int getParagraphsNumber() throws ApiException;
|
int getParagraphsNumber() throws ApiException;
|
||||||
public int getElementsNumber(int paragraphIndex) throws ApiException;
|
int getElementsNumber(int paragraphIndex) throws ApiException;
|
||||||
public String getParagraphText(int paragraphIndex) throws ApiException;
|
String getParagraphText(int paragraphIndex) throws ApiException;
|
||||||
|
|
||||||
// page information
|
// page information
|
||||||
public TextPosition getPageStart() throws ApiException;
|
TextPosition getPageStart() throws ApiException;
|
||||||
public TextPosition getPageEnd() throws ApiException;
|
TextPosition getPageEnd() throws ApiException;
|
||||||
|
boolean isPageEndOfSection() throws ApiException;
|
||||||
|
boolean isPageEndOfText() throws ApiException;
|
||||||
|
|
||||||
// manage view
|
// manage view
|
||||||
public void setPageStart(TextPosition position) throws ApiException;
|
void setPageStart(TextPosition position) throws ApiException;
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,6 +52,10 @@ public class ApiImplementation extends ApiInterface.Stub implements ApiMethods {
|
||||||
return getTextPosition(myReader.getTextView().getStartCursor());
|
return getTextPosition(myReader.getTextView().getStartCursor());
|
||||||
case GET_PAGE_END:
|
case GET_PAGE_END:
|
||||||
return getTextPosition(myReader.getTextView().getEndCursor());
|
return getTextPosition(myReader.getTextView().getEndCursor());
|
||||||
|
case IS_PAGE_END_OF_SECTION:
|
||||||
|
return ApiObject.envelope(isPageEndOfSection());
|
||||||
|
case IS_PAGE_END_OF_TEXT:
|
||||||
|
return ApiObject.envelope(isPageEndOfText());
|
||||||
case SET_PAGE_START:
|
case SET_PAGE_START:
|
||||||
setPageStart(
|
setPageStart(
|
||||||
(TextPosition)parameters[0]
|
(TextPosition)parameters[0]
|
||||||
|
@ -77,6 +81,16 @@ public class ApiImplementation extends ApiInterface.Stub implements ApiMethods {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isPageEndOfSection() {
|
||||||
|
final ZLTextWordCursor cursor = myReader.getTextView().getEndCursor();
|
||||||
|
return cursor.isEndOfParagraph() && cursor.getParagraphCursor().isEndOfSection();
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isPageEndOfText() {
|
||||||
|
final ZLTextWordCursor cursor = myReader.getTextView().getEndCursor();
|
||||||
|
return cursor.isEndOfParagraph() && cursor.getParagraphCursor().isLast();
|
||||||
|
}
|
||||||
|
|
||||||
private void setPageStart(TextPosition position) {
|
private void setPageStart(TextPosition position) {
|
||||||
myReader.getTextView().gotoPosition(position.ParagraphIndex, position.ElementIndex, position.CharIndex);
|
myReader.getTextView().gotoPosition(position.ParagraphIndex, position.ElementIndex, position.CharIndex);
|
||||||
myReader.getViewWidget().repaint();
|
myReader.getViewWidget().repaint();
|
||||||
|
|
|
@ -33,6 +33,10 @@ interface ApiMethods {
|
||||||
|
|
||||||
// book information
|
// book information
|
||||||
int GET_BOOK_LANGUAGE = 501;
|
int GET_BOOK_LANGUAGE = 501;
|
||||||
|
int GET_BOOK_TITLE = 502;
|
||||||
|
int GET_BOOK_AUTHORS = 503;
|
||||||
|
int GET_BOOK_TAGS = 504;
|
||||||
|
int GET_BOOK_FILENAME = 505;
|
||||||
|
|
||||||
// text information
|
// text information
|
||||||
int GET_PARAGRAPHS_NUMBER = 601;
|
int GET_PARAGRAPHS_NUMBER = 601;
|
||||||
|
@ -42,6 +46,8 @@ interface ApiMethods {
|
||||||
// page information
|
// page information
|
||||||
int GET_PAGE_START = 701;
|
int GET_PAGE_START = 701;
|
||||||
int GET_PAGE_END = 702;
|
int GET_PAGE_END = 702;
|
||||||
|
int IS_PAGE_END_OF_TEXT = 703;
|
||||||
|
int IS_PAGE_END_OF_SECTION = 704;
|
||||||
|
|
||||||
// view change
|
// view change
|
||||||
int SET_PAGE_START = 801;
|
int SET_PAGE_START = 801;
|
||||||
|
|
|
@ -28,7 +28,8 @@ public abstract class ApiObject implements Parcelable {
|
||||||
int VOID = 0;
|
int VOID = 0;
|
||||||
int INT = 1;
|
int INT = 1;
|
||||||
int STRING = 2;
|
int STRING = 2;
|
||||||
int TEXT_POSITION = 3;
|
int BOOLEAN = 3;
|
||||||
|
int TEXT_POSITION = 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
static class Void extends ApiObject {
|
static class Void extends ApiObject {
|
||||||
|
@ -62,22 +63,22 @@ public abstract class ApiObject implements Parcelable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static class Error extends ApiObject {
|
static class Boolean extends ApiObject {
|
||||||
final java.lang.String Message;
|
final boolean Value;
|
||||||
|
|
||||||
Error(java.lang.String message) {
|
Boolean(boolean value) {
|
||||||
Message = message;
|
Value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int type() {
|
protected int type() {
|
||||||
return Type.ERROR;
|
return Type.BOOLEAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeToParcel(Parcel parcel, int flags) {
|
public void writeToParcel(Parcel parcel, int flags) {
|
||||||
super.writeToParcel(parcel, flags);
|
super.writeToParcel(parcel, flags);
|
||||||
parcel.writeString(Message);
|
parcel.writeByte((byte)(Value ? 1 : 0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -100,10 +101,33 @@ public abstract class ApiObject implements Parcelable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static class Error extends ApiObject {
|
||||||
|
final java.lang.String Message;
|
||||||
|
|
||||||
|
Error(java.lang.String message) {
|
||||||
|
Message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected int type() {
|
||||||
|
return Type.ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void writeToParcel(Parcel parcel, int flags) {
|
||||||
|
super.writeToParcel(parcel, flags);
|
||||||
|
parcel.writeString(Message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static ApiObject envelope(int value) {
|
static ApiObject envelope(int value) {
|
||||||
return new Integer(value);
|
return new Integer(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static ApiObject envelope(boolean value) {
|
||||||
|
return new Boolean(value);
|
||||||
|
}
|
||||||
|
|
||||||
static ApiObject envelope(java.lang.String value) {
|
static ApiObject envelope(java.lang.String value) {
|
||||||
return new String(value);
|
return new String(value);
|
||||||
}
|
}
|
||||||
|
@ -131,6 +155,8 @@ public abstract class ApiObject implements Parcelable {
|
||||||
return Void.Instance;
|
return Void.Instance;
|
||||||
case Type.INT:
|
case Type.INT:
|
||||||
return new Integer(parcel.readInt());
|
return new Integer(parcel.readInt());
|
||||||
|
case Type.BOOLEAN:
|
||||||
|
return new Boolean(parcel.readByte() == 1);
|
||||||
case Type.STRING:
|
case Type.STRING:
|
||||||
return new String(parcel.readString());
|
return new String(parcel.readString());
|
||||||
case Type.TEXT_POSITION:
|
case Type.TEXT_POSITION:
|
||||||
|
|
|
@ -91,6 +91,14 @@ public class ApiServiceConnection implements ServiceConnection, Api, ApiMethods
|
||||||
return ((ApiObject.Integer)object).Value;
|
return ((ApiObject.Integer)object).Value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean requestBoolean(int method, ApiObject[] params) throws ApiException {
|
||||||
|
final ApiObject object = request(method, params);
|
||||||
|
if (!(object instanceof ApiObject.Boolean)) {
|
||||||
|
throw new ApiException("Cannot cast return type of method " + method + " to boolean");
|
||||||
|
}
|
||||||
|
return ((ApiObject.Boolean)object).Value;
|
||||||
|
}
|
||||||
|
|
||||||
private TextPosition requestTextPosition(int method, ApiObject[] params) throws ApiException {
|
private TextPosition requestTextPosition(int method, ApiObject[] params) throws ApiException {
|
||||||
final ApiObject object = request(method, params);
|
final ApiObject object = request(method, params);
|
||||||
if (!(object instanceof TextPosition)) {
|
if (!(object instanceof TextPosition)) {
|
||||||
|
@ -113,6 +121,14 @@ public class ApiServiceConnection implements ServiceConnection, Api, ApiMethods
|
||||||
return requestString(GET_BOOK_LANGUAGE, EMPTY_PARAMETERS);
|
return requestString(GET_BOOK_LANGUAGE, EMPTY_PARAMETERS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getBookTitle() throws ApiException {
|
||||||
|
return requestString(GET_BOOK_TITLE, EMPTY_PARAMETERS);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getBookFileName() throws ApiException {
|
||||||
|
return requestString(GET_BOOK_FILENAME, EMPTY_PARAMETERS);
|
||||||
|
}
|
||||||
|
|
||||||
public TextPosition getPageStart() throws ApiException {
|
public TextPosition getPageStart() throws ApiException {
|
||||||
return requestTextPosition(GET_PAGE_START, EMPTY_PARAMETERS);
|
return requestTextPosition(GET_PAGE_START, EMPTY_PARAMETERS);
|
||||||
}
|
}
|
||||||
|
@ -121,6 +137,14 @@ public class ApiServiceConnection implements ServiceConnection, Api, ApiMethods
|
||||||
return requestTextPosition(GET_PAGE_END, EMPTY_PARAMETERS);
|
return requestTextPosition(GET_PAGE_END, EMPTY_PARAMETERS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isPageEndOfSection() throws ApiException {
|
||||||
|
return requestBoolean(IS_PAGE_END_OF_SECTION, EMPTY_PARAMETERS);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isPageEndOfText() throws ApiException {
|
||||||
|
return requestBoolean(IS_PAGE_END_OF_TEXT, EMPTY_PARAMETERS);
|
||||||
|
}
|
||||||
|
|
||||||
public void setPageStart(TextPosition position) throws ApiException {
|
public void setPageStart(TextPosition position) throws ApiException {
|
||||||
request(SET_PAGE_START, new ApiObject[] { position });
|
request(SET_PAGE_START, new ApiObject[] { position });
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue