mirror of
https://github.com/dgis/emu48android
synced 2025-01-27 07:58:07 +01:00
Refactor to Java 1.8
This commit is contained in:
parent
d8fb3a9ec0
commit
2123f5c45c
5 changed files with 184 additions and 261 deletions
|
@ -616,13 +616,10 @@ public class PanAndScaleView extends View {
|
||||||
|
|
||||||
boolean osdAllowed = false;
|
boolean osdAllowed = false;
|
||||||
Handler osdTimerHandler = new Handler();
|
Handler osdTimerHandler = new Handler();
|
||||||
Runnable osdTimerRunnable = new Runnable() {
|
Runnable osdTimerRunnable = () -> {
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
// OSD should stop now!
|
// OSD should stop now!
|
||||||
osdAllowed = false;
|
osdAllowed = false;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void startOSDTimer() {
|
void startOSDTimer() {
|
||||||
|
|
|
@ -17,8 +17,6 @@ package org.emulator.calculator;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Based on the free HP82240B Printer Simulator by Christoph Giesselink
|
* Based on the free HP82240B Printer Simulator by Christoph Giesselink
|
||||||
*/
|
*/
|
||||||
|
@ -26,7 +24,6 @@ public class PrinterSimulator {
|
||||||
|
|
||||||
private static final String TAG = "PrinterSimulator";
|
private static final String TAG = "PrinterSimulator";
|
||||||
private boolean debug = false;
|
private boolean debug = false;
|
||||||
private ArrayList<Integer> data = new ArrayList<>();
|
|
||||||
private StringBuilder m_Text = new StringBuilder();
|
private StringBuilder m_Text = new StringBuilder();
|
||||||
private StringBuilder textUpdate = new StringBuilder();
|
private StringBuilder textUpdate = new StringBuilder();
|
||||||
|
|
||||||
|
@ -188,8 +185,6 @@ public class PrinterSimulator {
|
||||||
|
|
||||||
textUpdate.setLength(0);
|
textUpdate.setLength(0);
|
||||||
|
|
||||||
data.add(byData);
|
|
||||||
|
|
||||||
do {
|
do {
|
||||||
// check for begin of ESC sequence
|
// check for begin of ESC sequence
|
||||||
if (byData == ESC && !m_bEsc && m_byGraphLength == 0) {
|
if (byData == ESC && !m_bEsc && m_byGraphLength == 0) {
|
||||||
|
|
|
@ -27,7 +27,6 @@ import android.os.Bundle;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.MenuItem;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.view.Window;
|
import android.view.Window;
|
||||||
|
@ -113,19 +112,12 @@ public class PrinterSimulatorFragment extends AppCompatDialogFragment {
|
||||||
toolbar.setTitle(title);
|
toolbar.setTitle(title);
|
||||||
toolbar.setNavigationIcon(Utils.resId(this, "drawable", "ic_keyboard_backspace_white_24dp"));
|
toolbar.setNavigationIcon(Utils.resId(this, "drawable", "ic_keyboard_backspace_white_24dp"));
|
||||||
toolbar.setNavigationOnClickListener(
|
toolbar.setNavigationOnClickListener(
|
||||||
new View.OnClickListener() {
|
v -> dismiss()
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
dismiss();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
toolbar.inflateMenu(Utils.resId(this, "menu", "fragment_printer_simulator"));
|
toolbar.inflateMenu(Utils.resId(this, "menu", "fragment_printer_simulator"));
|
||||||
toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
|
toolbar.setOnMenuItemClickListener(item -> {
|
||||||
@Override
|
|
||||||
public boolean onMenuItemClick(MenuItem item) {
|
|
||||||
if(item.getItemId() == Utils.resId(PrinterSimulatorFragment.this, "id", "menu_printer_simulator_share_text")) {
|
if(item.getItemId() == Utils.resId(PrinterSimulatorFragment.this, "id", "menu_printer_simulator_share_text")) {
|
||||||
Intent intent = new Intent(android.content.Intent.ACTION_SEND);
|
Intent intent = new Intent(Intent.ACTION_SEND);
|
||||||
intent.setType("text/plain");
|
intent.setType("text/plain");
|
||||||
intent.putExtra(Intent.EXTRA_SUBJECT, Utils.resId(PrinterSimulatorFragment.this, "string", "message_printer_share_text"));
|
intent.putExtra(Intent.EXTRA_SUBJECT, Utils.resId(PrinterSimulatorFragment.this, "string", "message_printer_share_text"));
|
||||||
intent.putExtra(Intent.EXTRA_TEXT, printerSimulator.getText());
|
intent.putExtra(Intent.EXTRA_TEXT, printerSimulator.getText());
|
||||||
|
@ -147,7 +139,7 @@ public class PrinterSimulatorFragment extends AppCompatDialogFragment {
|
||||||
croppedPaperBitmap.compress(Bitmap.CompressFormat.PNG, 90, fileOutputStream);
|
croppedPaperBitmap.compress(Bitmap.CompressFormat.PNG, 90, fileOutputStream);
|
||||||
fileOutputStream.close();
|
fileOutputStream.close();
|
||||||
String mimeType = "application/png";
|
String mimeType = "application/png";
|
||||||
Intent intent = new Intent(android.content.Intent.ACTION_SEND);
|
Intent intent = new Intent(Intent.ACTION_SEND);
|
||||||
intent.setType(mimeType);
|
intent.setType(mimeType);
|
||||||
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
intent.putExtra(Intent.EXTRA_SUBJECT, Utils.resId(PrinterSimulatorFragment.this, "string", "message_printer_share_graphic"));
|
intent.putExtra(Intent.EXTRA_SUBJECT, Utils.resId(PrinterSimulatorFragment.this, "string", "message_printer_share_graphic"));
|
||||||
|
@ -169,7 +161,6 @@ public class PrinterSimulatorFragment extends AppCompatDialogFragment {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
});
|
});
|
||||||
setMenuVisibility(true);
|
setMenuVisibility(true);
|
||||||
|
|
||||||
|
@ -235,21 +226,15 @@ public class PrinterSimulatorFragment extends AppCompatDialogFragment {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPrinterSimulator(final PrinterSimulator printerSimulator) {
|
public void setPrinterSimulator(PrinterSimulator printerSimulator) {
|
||||||
this.printerSimulator = printerSimulator;
|
this.printerSimulator = printerSimulator;
|
||||||
this.printerSimulator.setOnPrinterUpdateListener(new PrinterSimulator.OnPrinterUpdateListener() {
|
this.printerSimulator.setOnPrinterUpdateListener(textAppended -> {
|
||||||
@Override
|
|
||||||
public void onPrinterUpdate(final String textAppended) {
|
|
||||||
Activity activity = getActivity();
|
Activity activity = getActivity();
|
||||||
if(activity != null)
|
if(activity != null)
|
||||||
activity.runOnUiThread(new Runnable() {
|
activity.runOnUiThread(() -> {
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
if(debug) Log.d(TAG, "onPrinterUpdate(" + textAppended + ")");
|
if(debug) Log.d(TAG, "onPrinterUpdate(" + textAppended + ")");
|
||||||
updatePaper(textAppended);
|
updatePaper(textAppended);
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -74,7 +74,6 @@ import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
|
@ -134,7 +133,7 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
final Toolbar toolbar = findViewById(R.id.toolbar);
|
Toolbar toolbar = findViewById(R.id.toolbar);
|
||||||
setSupportActionBar(toolbar);
|
setSupportActionBar(toolbar);
|
||||||
toolbar.setVisibility(View.GONE);
|
toolbar.setVisibility(View.GONE);
|
||||||
|
|
||||||
|
@ -187,19 +186,10 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
|
|
||||||
|
|
||||||
fragmentPrinterSimulator.setPrinterSimulator(printerSimulator);
|
fragmentPrinterSimulator.setPrinterSimulator(printerSimulator);
|
||||||
printerSimulator.setOnPrinterOutOfPaperListener(new PrinterSimulator.OnPrinterOutOfPaperListener() {
|
printerSimulator.setOnPrinterOutOfPaperListener((currentLine, maxLine, currentPixelRow, maxPixelRow) -> runOnUiThread(
|
||||||
@Override
|
() -> Toast.makeText(MainActivity.this, String.format(Locale.US, getString(R.string.message_printer_out_of_paper), maxLine, maxPixelRow), Toast.LENGTH_LONG).show()
|
||||||
public void onPrinterOutOfPaper(final int currentLine, final int maxLine, final int currentPixelRow, final int maxPixelRow) {
|
)
|
||||||
runOnUiThread(new Runnable() {
|
);
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
Toast.makeText(MainActivity.this, String.format(Locale.US,
|
|
||||||
getString(R.string.message_printer_out_of_paper),
|
|
||||||
maxLine, maxPixelRow), Toast.LENGTH_LONG).show();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
//android.os.Debug.waitForDebugger();
|
//android.os.Debug.waitForDebugger();
|
||||||
|
@ -387,16 +377,13 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
String[] mrus = mruLinkedHashMapKeySet.toArray(new String[mruLength]);
|
String[] mrus = mruLinkedHashMapKeySet.toArray(new String[mruLength]);
|
||||||
|
|
||||||
int mruClickedIndex = id - MRU_ID_START;
|
int mruClickedIndex = id - MRU_ID_START;
|
||||||
final String url = mrus[mruClickedIndex];
|
String url = mrus[mruClickedIndex];
|
||||||
mruLinkedHashMap.get(url);
|
mruLinkedHashMap.get(url);
|
||||||
|
|
||||||
ensureDocumentSaved(new Runnable() {
|
ensureDocumentSaved(() -> {
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
if(onFileOpen(url) != 0) {
|
if(onFileOpen(url) != 0) {
|
||||||
saveLastDocument(url);
|
saveLastDocument(url);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -519,9 +506,9 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
DocumentFile kmlFolderDocumentFile = DocumentFile.fromTreeUri(this, kmlFolderUri);
|
DocumentFile kmlFolderDocumentFile = DocumentFile.fromTreeUri(this, kmlFolderUri);
|
||||||
if(kmlFolderDocumentFile != null) {
|
if(kmlFolderDocumentFile != null) {
|
||||||
for (DocumentFile file : kmlFolderDocumentFile.listFiles()) {
|
for (DocumentFile file : kmlFolderDocumentFile.listFiles()) {
|
||||||
final String url = file.getUri().toString();
|
String url = file.getUri().toString();
|
||||||
final String name = file.getName();
|
String name = file.getName();
|
||||||
final String mime = file.getType();
|
String mime = file.getType();
|
||||||
Log.d(TAG, "url: " + url + ", name: " + name + ", mime: " + mime);
|
Log.d(TAG, "url: " + url + ", name: " + name + ", mime: " + mime);
|
||||||
if(kmlMimeType.equals(mime)) {
|
if(kmlMimeType.equals(mime)) {
|
||||||
calculatorsAssetFilenames.add(url);
|
calculatorsAssetFilenames.add(url);
|
||||||
|
@ -595,27 +582,21 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Collections.sort(kmlScripts, new Comparator<KMLScriptItem>() {
|
Collections.sort(kmlScripts, (lhs, rhs) -> lhs.title.compareTo(rhs.title));
|
||||||
@Override
|
|
||||||
public int compare(KMLScriptItem lhs, KMLScriptItem rhs) {
|
|
||||||
return lhs.title.compareTo(rhs.title);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ensureDocumentSaved(final Runnable continueCallback) {
|
private void ensureDocumentSaved(Runnable continueCallback) {
|
||||||
ensureDocumentSaved(continueCallback, false);
|
ensureDocumentSaved(continueCallback, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Runnable fileSaveAsCallback = null;
|
private Runnable fileSaveAsCallback = null;
|
||||||
private void ensureDocumentSaved(final Runnable continueCallback, boolean forceRequest) {
|
private void ensureDocumentSaved(Runnable continueCallback, boolean forceRequest) {
|
||||||
if(NativeLib.isDocumentAvailable()) {
|
if(NativeLib.isDocumentAvailable()) {
|
||||||
final String currentFilename = NativeLib.getCurrentFilename();
|
String currentFilename = NativeLib.getCurrentFilename();
|
||||||
final boolean hasFilename = (currentFilename != null && currentFilename.length() > 0);
|
boolean hasFilename = (currentFilename != null && currentFilename.length() > 0);
|
||||||
|
|
||||||
DialogInterface.OnClickListener onClickListener = new DialogInterface.OnClickListener() {
|
DialogInterface.OnClickListener onClickListener = (dialog, which) -> {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (which == DialogInterface.BUTTON_POSITIVE) {
|
if (which == DialogInterface.BUTTON_POSITIVE) {
|
||||||
if (hasFilename) {
|
if (hasFilename) {
|
||||||
if(NativeLib.onFileSave() == 1)
|
if(NativeLib.onFileSave() == 1)
|
||||||
|
@ -630,7 +611,6 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
if(continueCallback != null)
|
if(continueCallback != null)
|
||||||
continueCallback.run();
|
continueCallback.run();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
if(!forceRequest && hasFilename && sharedPreferences.getBoolean("settings_autosave", true)) {
|
if(!forceRequest && hasFilename && sharedPreferences.getBoolean("settings_autosave", true)) {
|
||||||
|
@ -650,12 +630,7 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
// By default Port1 is set
|
// By default Port1 is set
|
||||||
setPort1Settings(true, true);
|
setPort1Settings(true, true);
|
||||||
|
|
||||||
ensureDocumentSaved(new Runnable() {
|
ensureDocumentSaved(() -> showKMLPicker(false));
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
showKMLPicker(false);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void newFileFromKML(String kmlScriptFilename) {
|
private void newFileFromKML(String kmlScriptFilename) {
|
||||||
|
@ -670,15 +645,12 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnFileOpen() {
|
private void OnFileOpen() {
|
||||||
ensureDocumentSaved(new Runnable() {
|
ensureDocumentSaved(() -> {
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
|
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
|
||||||
intent.addCategory(Intent.CATEGORY_OPENABLE);
|
intent.addCategory(Intent.CATEGORY_OPENABLE);
|
||||||
intent.setType("*/*");
|
intent.setType("*/*");
|
||||||
intent.putExtra(Intent.EXTRA_TITLE, getString(R.string.filename) + "-state.e48");
|
intent.putExtra(Intent.EXTRA_TITLE, getString(R.string.filename) + "-state.e48");
|
||||||
startActivityForResult(intent, INTENT_GETOPENFILENAME);
|
startActivityForResult(intent, INTENT_GETOPENFILENAME);
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
private void OnFileSave() {
|
private void OnFileSave() {
|
||||||
|
@ -722,21 +694,14 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
startActivityForResult(intent, INTENT_GETSAVEFILENAME);
|
startActivityForResult(intent, INTENT_GETSAVEFILENAME);
|
||||||
}
|
}
|
||||||
private void OnFileClose() {
|
private void OnFileClose() {
|
||||||
ensureDocumentSaved(new Runnable() {
|
ensureDocumentSaved(() -> {
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
NativeLib.onFileClose();
|
NativeLib.onFileClose();
|
||||||
showCalculatorView(false);
|
showCalculatorView(false);
|
||||||
saveLastDocument("");
|
saveLastDocument("");
|
||||||
updateNavigationDrawerItems();
|
updateNavigationDrawerItems();
|
||||||
displayFilename("");
|
displayFilename("");
|
||||||
if(drawer != null) {
|
if(drawer != null) {
|
||||||
new android.os.Handler().postDelayed(new Runnable() {
|
new android.os.Handler().postDelayed(() -> drawer.openDrawer(GravityCompat.START), 300);
|
||||||
public void run() {
|
|
||||||
drawer.openDrawer(GravityCompat.START);
|
|
||||||
}
|
|
||||||
}, 300);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}, true);
|
}, true);
|
||||||
}
|
}
|
||||||
|
@ -755,12 +720,10 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
|
|
||||||
private void OnObjectLoad() {
|
private void OnObjectLoad() {
|
||||||
if(sharedPreferences.getBoolean("settings_objectloadwarning", false)) {
|
if(sharedPreferences.getBoolean("settings_objectloadwarning", false)) {
|
||||||
DialogInterface.OnClickListener onClickListener = new DialogInterface.OnClickListener() {
|
DialogInterface.OnClickListener onClickListener = (dialog, which) -> {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (which == DialogInterface.BUTTON_POSITIVE) {
|
if (which == DialogInterface.BUTTON_POSITIVE) {
|
||||||
openDocument();
|
openDocument();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
new AlertDialog.Builder(this)
|
new AlertDialog.Builder(this)
|
||||||
.setMessage(getString(R.string.message_object_load))
|
.setMessage(getString(R.string.message_object_load))
|
||||||
|
@ -812,12 +775,10 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
NativeLib.onStackPaste();
|
NativeLib.onStackPaste();
|
||||||
}
|
}
|
||||||
private void OnViewReset() {
|
private void OnViewReset() {
|
||||||
DialogInterface.OnClickListener onClickListener = new DialogInterface.OnClickListener() {
|
DialogInterface.OnClickListener onClickListener = (dialog, which) -> {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (which == DialogInterface.BUTTON_POSITIVE) {
|
if (which == DialogInterface.BUTTON_POSITIVE) {
|
||||||
NativeLib.onViewReset();
|
NativeLib.onViewReset();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
new AlertDialog.Builder(this)
|
new AlertDialog.Builder(this)
|
||||||
.setMessage(getString(R.string.message_press_reset))
|
.setMessage(getString(R.string.message_press_reset))
|
||||||
|
@ -850,10 +811,10 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
fragmentPrinterSimulator.show(getSupportFragmentManager(), "Hello Fragment");
|
fragmentPrinterSimulator.show(getSupportFragmentManager(), "Hello Fragment");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void showKMLPicker(final boolean changeKML) {
|
private void showKMLPicker(boolean changeKML) {
|
||||||
extractKMLScripts();
|
extractKMLScripts();
|
||||||
|
|
||||||
final ArrayList<KMLScriptItem> kmlScriptsForCurrentModel;
|
ArrayList<KMLScriptItem> kmlScriptsForCurrentModel;
|
||||||
if(changeKML) {
|
if(changeKML) {
|
||||||
kmlScriptsForCurrentModel = new ArrayList<>();
|
kmlScriptsForCurrentModel = new ArrayList<>();
|
||||||
char m = (char) NativeLib.getCurrentModel();
|
char m = (char) NativeLib.getCurrentModel();
|
||||||
|
@ -866,8 +827,8 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
kmlScriptsForCurrentModel = kmlScripts;
|
kmlScriptsForCurrentModel = kmlScripts;
|
||||||
|
|
||||||
boolean hasEmbeddedKMLs = getPackageName().contains("org.emulator.forty.eight");
|
boolean hasEmbeddedKMLs = getPackageName().contains("org.emulator.forty.eight");
|
||||||
final int lastIndex = kmlScriptsForCurrentModel.size();
|
int lastIndex = kmlScriptsForCurrentModel.size();
|
||||||
final String[] kmlScriptTitles = new String[lastIndex + (hasEmbeddedKMLs ? 2 : 1)];
|
String[] kmlScriptTitles = new String[lastIndex + (hasEmbeddedKMLs ? 2 : 1)];
|
||||||
for (int i = 0; i < kmlScriptsForCurrentModel.size(); i++)
|
for (int i = 0; i < kmlScriptsForCurrentModel.size(); i++)
|
||||||
kmlScriptTitles[i] = kmlScriptsForCurrentModel.get(i).title;
|
kmlScriptTitles[i] = kmlScriptsForCurrentModel.get(i).title;
|
||||||
kmlScriptTitles[lastIndex] = getResources().getString(R.string.load_custom_kml);
|
kmlScriptTitles[lastIndex] = getResources().getString(R.string.load_custom_kml);
|
||||||
|
@ -875,9 +836,7 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
kmlScriptTitles[lastIndex + 1] = getResources().getString(R.string.load_default_kml);
|
kmlScriptTitles[lastIndex + 1] = getResources().getString(R.string.load_default_kml);
|
||||||
new AlertDialog.Builder(MainActivity.this)
|
new AlertDialog.Builder(MainActivity.this)
|
||||||
.setTitle(getResources().getString(R.string.pick_calculator))
|
.setTitle(getResources().getString(R.string.pick_calculator))
|
||||||
.setItems(kmlScriptTitles, new DialogInterface.OnClickListener() {
|
.setItems(kmlScriptTitles, (dialog, which) -> {
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if(which == lastIndex) {
|
if(which == lastIndex) {
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) { // < API 21
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) { // < API 21
|
||||||
new AlertDialog.Builder(MainActivity.this)
|
new AlertDialog.Builder(MainActivity.this)
|
||||||
|
@ -914,7 +873,6 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
} else
|
} else
|
||||||
newFileFromKML(kmlScriptFilename);
|
newFileFromKML(kmlScriptFilename);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}).show();
|
}).show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1172,12 +1130,12 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
}
|
}
|
||||||
|
|
||||||
private void makeUriPersistable(Intent data, Uri uri) {
|
private void makeUriPersistable(Intent data, Uri uri) {
|
||||||
final int takeFlags = data.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
|
int takeFlags = data.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT)
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT)
|
||||||
getContentResolver().takePersistableUriPermission(uri, takeFlags);
|
getContentResolver().takePersistableUriPermission(uri, takeFlags);
|
||||||
}
|
}
|
||||||
private void makeUriPersistableReadOnly(Intent data, Uri uri) {
|
private void makeUriPersistableReadOnly(Intent data, Uri uri) {
|
||||||
final int takeFlags = data.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION);
|
int takeFlags = data.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT)
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT)
|
||||||
getContentResolver().takePersistableUriPermission(uri, takeFlags);
|
getContentResolver().takePersistableUriPermission(uri, takeFlags);
|
||||||
}
|
}
|
||||||
|
@ -1288,8 +1246,8 @@ public class MainActivity extends AppCompatActivity implements NavigationView.On
|
||||||
DocumentFile folderDocumentFile = DocumentFile.fromTreeUri(this, folderURI);
|
DocumentFile folderDocumentFile = DocumentFile.fromTreeUri(this, folderURI);
|
||||||
if(folderDocumentFile != null) {
|
if(folderDocumentFile != null) {
|
||||||
for (DocumentFile file : folderDocumentFile.listFiles()) {
|
for (DocumentFile file : folderDocumentFile.listFiles()) {
|
||||||
final String url = file.getUri().toString();
|
String url = file.getUri().toString();
|
||||||
final String name = file.getName();
|
String name = file.getName();
|
||||||
//Log.d(TAG, "url: " + url + ", name: " + name);
|
//Log.d(TAG, "url: " + url + ", name: " + name);
|
||||||
if (filename.equals(name)) {
|
if (filename.equals(name)) {
|
||||||
return openFileFromContentResolver(url, writeAccess);
|
return openFileFromContentResolver(url, writeAccess);
|
||||||
|
|
|
@ -122,9 +122,7 @@ public class SettingsActivity extends AppCompatActivity implements SharedPrefere
|
||||||
// final ColorPickerPreferenceCompat preferenceBackgroundCustomColor = (ColorPickerPreferenceCompat)findPreference("settings_background_custom_color");
|
// final ColorPickerPreferenceCompat preferenceBackgroundCustomColor = (ColorPickerPreferenceCompat)findPreference("settings_background_custom_color");
|
||||||
if(preferenceBackgroundFallbackColor != null /*&& preferenceBackgroundCustomColor != null*/) {
|
if(preferenceBackgroundFallbackColor != null /*&& preferenceBackgroundCustomColor != null*/) {
|
||||||
final String[] stringArrayBackgroundFallbackColor = getResources().getStringArray(R.array.settings_background_fallback_color_item);
|
final String[] stringArrayBackgroundFallbackColor = getResources().getStringArray(R.array.settings_background_fallback_color_item);
|
||||||
Preference.OnPreferenceChangeListener onPreferenceChangeListenerBackgroundFallbackColor = new Preference.OnPreferenceChangeListener() {
|
Preference.OnPreferenceChangeListener onPreferenceChangeListenerBackgroundFallbackColor = (preference, value) -> {
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object value) {
|
|
||||||
if(value != null) {
|
if(value != null) {
|
||||||
String stringValue = value.toString();
|
String stringValue = value.toString();
|
||||||
int backgroundFallbackColor = -1;
|
int backgroundFallbackColor = -1;
|
||||||
|
@ -136,7 +134,6 @@ public class SettingsActivity extends AppCompatActivity implements SharedPrefere
|
||||||
// preferenceBackgroundCustomColor.setEnabled(backgroundFallbackColor == 2);
|
// preferenceBackgroundCustomColor.setEnabled(backgroundFallbackColor == 2);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
};
|
};
|
||||||
preferenceBackgroundFallbackColor.setOnPreferenceChangeListener(onPreferenceChangeListenerBackgroundFallbackColor);
|
preferenceBackgroundFallbackColor.setOnPreferenceChangeListener(onPreferenceChangeListenerBackgroundFallbackColor);
|
||||||
onPreferenceChangeListenerBackgroundFallbackColor.onPreferenceChange(preferenceBackgroundFallbackColor,
|
onPreferenceChangeListenerBackgroundFallbackColor.onPreferenceChange(preferenceBackgroundFallbackColor,
|
||||||
|
@ -161,15 +158,12 @@ public class SettingsActivity extends AppCompatActivity implements SharedPrefere
|
||||||
// Macro
|
// Macro
|
||||||
|
|
||||||
Preference preferenceMacroRealSpeed = findPreference("settings_macro_real_speed");
|
Preference preferenceMacroRealSpeed = findPreference("settings_macro_real_speed");
|
||||||
final Preference preferenceMacroManualSpeed = findPreference("settings_macro_manual_speed");
|
Preference preferenceMacroManualSpeed = findPreference("settings_macro_manual_speed");
|
||||||
if(preferenceMacroRealSpeed != null && preferenceMacroManualSpeed != null) {
|
if(preferenceMacroRealSpeed != null && preferenceMacroManualSpeed != null) {
|
||||||
Preference.OnPreferenceChangeListener onPreferenceChangeListenerMacroRealSpeed = new Preference.OnPreferenceChangeListener() {
|
Preference.OnPreferenceChangeListener onPreferenceChangeListenerMacroRealSpeed = (preference, value) -> {
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object value) {
|
|
||||||
if(value != null)
|
if(value != null)
|
||||||
preferenceMacroManualSpeed.setEnabled(!(Boolean) value);
|
preferenceMacroManualSpeed.setEnabled(!(Boolean) value);
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
};
|
};
|
||||||
preferenceMacroRealSpeed.setOnPreferenceChangeListener(onPreferenceChangeListenerMacroRealSpeed);
|
preferenceMacroRealSpeed.setOnPreferenceChangeListener(onPreferenceChangeListenerMacroRealSpeed);
|
||||||
onPreferenceChangeListenerMacroRealSpeed.onPreferenceChange(preferenceMacroRealSpeed, sharedPreferences.getBoolean(preferenceMacroRealSpeed.getKey(), true));
|
onPreferenceChangeListenerMacroRealSpeed.onPreferenceChange(preferenceMacroRealSpeed, sharedPreferences.getBoolean(preferenceMacroRealSpeed.getKey(), true));
|
||||||
|
@ -177,52 +171,46 @@ public class SettingsActivity extends AppCompatActivity implements SharedPrefere
|
||||||
|
|
||||||
// Ports 1 & 2 settings
|
// Ports 1 & 2 settings
|
||||||
|
|
||||||
final Preference preferencePort1en = findPreference("settings_port1en");
|
Preference preferencePort1en = findPreference("settings_port1en");
|
||||||
final Preference preferencePort1wr = findPreference("settings_port1wr");
|
Preference preferencePort1wr = findPreference("settings_port1wr");
|
||||||
final Preference preferencePort2en = findPreference("settings_port2en");
|
Preference preferencePort2en = findPreference("settings_port2en");
|
||||||
final Preference preferencePort2wr = findPreference("settings_port2wr");
|
Preference preferencePort2wr = findPreference("settings_port2wr");
|
||||||
preferencePort2load = findPreference("settings_port2load");
|
preferencePort2load = findPreference("settings_port2load");
|
||||||
|
if(preferencePort1en != null && preferencePort1wr != null
|
||||||
|
&& preferencePort2en != null && preferencePort2wr != null
|
||||||
|
&& preferencePort2load != null) {
|
||||||
|
boolean enablePortPreferences = NativeLib.isPortExtensionPossible();
|
||||||
|
|
||||||
final boolean enablePortPreferences = NativeLib.isPortExtensionPossible();
|
Preference.OnPreferenceChangeListener onPreferenceChangeListenerPort1en = (preference, value) -> {
|
||||||
|
|
||||||
Preference.OnPreferenceChangeListener onPreferenceChangeListenerPort1en = new Preference.OnPreferenceChangeListener() {
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object value) {
|
|
||||||
preferencePort1en.setEnabled(enablePortPreferences);
|
preferencePort1en.setEnabled(enablePortPreferences);
|
||||||
preferencePort1wr.setEnabled(enablePortPreferences);
|
preferencePort1wr.setEnabled(enablePortPreferences);
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
};
|
};
|
||||||
preferencePort1en.setOnPreferenceChangeListener(onPreferenceChangeListenerPort1en);
|
preferencePort1en.setOnPreferenceChangeListener(onPreferenceChangeListenerPort1en);
|
||||||
onPreferenceChangeListenerPort1en.onPreferenceChange(preferencePort1en, sharedPreferences.getBoolean(preferencePort1en.getKey(), false));
|
onPreferenceChangeListenerPort1en.onPreferenceChange(preferencePort1en, sharedPreferences.getBoolean(preferencePort1en.getKey(), false));
|
||||||
|
|
||||||
Preference.OnPreferenceChangeListener onPreferenceChangeListenerPort2en = new Preference.OnPreferenceChangeListener() {
|
Preference.OnPreferenceChangeListener onPreferenceChangeListenerPort2en = (preference, value) -> {
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object value) {
|
|
||||||
preferencePort2en.setEnabled(enablePortPreferences);
|
preferencePort2en.setEnabled(enablePortPreferences);
|
||||||
preferencePort2wr.setEnabled(enablePortPreferences);
|
preferencePort2wr.setEnabled(enablePortPreferences);
|
||||||
preferencePort2load.setEnabled(enablePortPreferences);
|
preferencePort2load.setEnabled(enablePortPreferences);
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
};
|
};
|
||||||
preferencePort2en.setOnPreferenceChangeListener(onPreferenceChangeListenerPort2en);
|
preferencePort2en.setOnPreferenceChangeListener(onPreferenceChangeListenerPort2en);
|
||||||
onPreferenceChangeListenerPort2en.onPreferenceChange(preferencePort2en, sharedPreferences.getBoolean(preferencePort2en.getKey(), false));
|
onPreferenceChangeListenerPort2en.onPreferenceChange(preferencePort2en, sharedPreferences.getBoolean(preferencePort2en.getKey(), false));
|
||||||
|
|
||||||
updatePort2LoadFilename(sharedPreferences.getString(preferencePort2load.getKey(), ""));
|
updatePort2LoadFilename(sharedPreferences.getString(preferencePort2load.getKey(), ""));
|
||||||
preferencePort2load.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
preferencePort2load.setOnPreferenceClickListener(preference -> {
|
||||||
@Override
|
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
|
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
|
||||||
intent.addCategory(Intent.CATEGORY_OPENABLE);
|
intent.addCategory(Intent.CATEGORY_OPENABLE);
|
||||||
intent.setType("*/*");
|
intent.setType("*/*");
|
||||||
intent.putExtra(Intent.EXTRA_TITLE, "shared.bin");
|
intent.putExtra(Intent.EXTRA_TITLE, "shared.bin");
|
||||||
Activity activity = getActivity();
|
Activity activity = getActivity();
|
||||||
if(activity != null)
|
if (activity != null)
|
||||||
activity.startActivityForResult(intent, MainActivity.INTENT_PORT2LOAD);
|
activity.startActivityForResult(intent, MainActivity.INTENT_PORT2LOAD);
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void updatePort2LoadFilename(String port2Filename) {
|
void updatePort2LoadFilename(String port2Filename) {
|
||||||
if(preferencePort2load != null) {
|
if(preferencePort2load != null) {
|
||||||
|
@ -259,7 +247,7 @@ public class SettingsActivity extends AppCompatActivity implements SharedPrefere
|
||||||
}
|
}
|
||||||
|
|
||||||
private void makeUriPersistable(Intent data, Uri uri) {
|
private void makeUriPersistable(Intent data, Uri uri) {
|
||||||
final int takeFlags = data.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
|
int takeFlags = data.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT)
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT)
|
||||||
getContentResolver().takePersistableUriPermission(uri, takeFlags);
|
getContentResolver().takePersistableUriPermission(uri, takeFlags);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue