Skip to content

Commit 3fecfa9

Browse files
author
hyb1996
committed
优化 编辑文件的多任务体验
1 parent ce54478 commit 3fecfa9

File tree

10 files changed

+50
-37
lines changed

10 files changed

+50
-37
lines changed

app/src/main/AndroidManifest.xml

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55

66

77
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
8-
<uses-permission android:name="android.permission.WRITE_EXTERNAL_SedTORAGE"/>
8+
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
99
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
1010
<uses-permission android:name="com.android.launcher.permission.INSTALL_SHORTCUT"/>
1111
<uses-permission android:name="com.android.launcher.permission.UNINSTALL_SHORTCUT"/>
@@ -84,6 +84,7 @@
8484
<activity
8585
android:name=".ui.edit.EditActivity_"
8686
android:configChanges="orientation|screenSize"
87+
android:launchMode="standard"
8788
android:multiprocess="true"
8889
android:taskAffinity="org.autojs.autojs.edit"
8990
android:theme="@style/EditorTheme">

app/src/main/java/org/autojs/autojs/external/open/EditIntentActivity.java

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,9 @@
55
import android.net.Uri;
66
import android.os.Bundle;
77
import android.os.Environment;
8+
89
import androidx.annotation.Nullable;
10+
911
import android.text.TextUtils;
1012
import android.widget.Toast;
1113

@@ -56,9 +58,9 @@ private void handleIntent() {
5658
}
5759
}
5860
if (!TextUtils.isEmpty(path)) {
59-
EditActivity.editFile(this, path);
61+
EditActivity.editFile(this, path, false);
6062
} else {
61-
EditActivity.editFile(this, uri);
63+
EditActivity.editFile(this, uri, false);
6264
}
6365
}
6466
}

app/src/main/java/org/autojs/autojs/model/script/Scripts.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -92,7 +92,7 @@ object Scripts {
9292

9393

9494
fun edit(context: Context, file: ScriptFile) {
95-
EditActivity.editFile(context, file.simplifiedName, file.path)
95+
EditActivity.editFile(context, file.simplifiedName, file.path, true)
9696
}
9797

9898
fun edit(context: Context, path: String) {

app/src/main/java/org/autojs/autojs/ui/edit/EditActivity.java

Lines changed: 28 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
package org.autojs.autojs.ui.edit;
22

33
import android.annotation.SuppressLint;
4+
import android.app.Activity;
45
import android.content.Context;
56
import android.content.Intent;
67
import android.net.Uri;
@@ -31,6 +32,7 @@
3132
import org.androidannotations.annotations.AfterViews;
3233
import org.androidannotations.annotations.EActivity;
3334
import org.androidannotations.annotations.ViewById;
35+
import org.autojs.autojs.ui.main.MainActivity_;
3436

3537
import java.io.File;
3638
import java.io.IOException;
@@ -56,35 +58,46 @@ public class EditActivity extends BaseActivity implements OnActivityResultDelega
5658
@ViewById(R.id.editor_view)
5759
EditorView mEditorView;
5860

59-
6061
private EditorMenu mEditorMenu;
6162
private RequestPermissionCallbacks mRequestPermissionCallbacks = new RequestPermissionCallbacks();
63+
private boolean mNewTask;
6264

63-
public static void editFile(Context context, String path) {
64-
editFile(context, null, path);
65+
public static void editFile(Context context, String path, boolean newTask) {
66+
editFile(context, null, path, newTask);
6567
}
6668

67-
public static void editFile(Context context, Uri uri) {
68-
context.startActivity(new Intent(context, EditActivity_.class)
69-
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
69+
public static void editFile(Context context, Uri uri, boolean newTask) {
70+
context.startActivity(newIntent(context, newTask)
7071
.setData(uri));
7172
}
7273

73-
public static void editFile(Context context, String name, String path) {
74-
context.startActivity(new Intent(context, EditActivity_.class)
75-
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
74+
public static void editFile(Context context, String name, String path, boolean newTask) {
75+
context.startActivity(newIntent(context, newTask)
7676
.putExtra(EXTRA_PATH, path)
7777
.putExtra(EXTRA_NAME, name));
7878
}
7979

80-
public static void viewContent(Context context, String name, String content) {
81-
context.startActivity(new Intent(context, EditActivity_.class)
82-
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
80+
public static void viewContent(Context context, String name, String content, boolean newTask) {
81+
context.startActivity(newIntent(context, newTask)
8382
.putExtra(EXTRA_CONTENT, content)
8483
.putExtra(EXTRA_NAME, name)
8584
.putExtra(EXTRA_READ_ONLY, true));
8685
}
8786

87+
private static Intent newIntent(Context context, boolean newTask) {
88+
Intent intent = new Intent(context, EditActivity_.class);
89+
if (newTask || !(context instanceof Activity)) {
90+
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
91+
}
92+
return intent;
93+
}
94+
95+
@Override
96+
protected void onCreate(@Nullable Bundle savedInstanceState) {
97+
super.onCreate(savedInstanceState);
98+
mNewTask = (getIntent().getFlags() & Intent.FLAG_ACTIVITY_NEW_TASK) != 0;
99+
}
100+
88101
@SuppressLint("CheckResult")
89102
@AfterViews
90103
void setUpViews() {
@@ -142,14 +155,6 @@ public boolean onPrepareOptionsMenu(Menu menu) {
142155
return super.onPrepareOptionsMenu(menu);
143156
}
144157

145-
public boolean onPrepareActionMode(Menu menu) {
146-
Log.d(LOG_TAG, "onPrepareActionMode: " + menu);
147-
boolean isScriptRunning = mEditorView.getScriptExecutionId() != ScriptExecution.NO_ID;
148-
MenuItem forceStopItem = menu.findItem(R.id.action_force_stop);
149-
forceStopItem.setEnabled(isScriptRunning);
150-
return super.onPrepareOptionsMenu(menu);
151-
}
152-
153158
@Override
154159
public void onActionModeStarted(ActionMode mode) {
155160
Log.d(LOG_TAG, "onActionModeStarted: " + mode);
@@ -207,6 +212,9 @@ private void finishAndRemoveFromRecents() {
207212
} else {
208213
finish();
209214
}
215+
if (mNewTask) {
216+
startActivity(new Intent(this, MainActivity_.class));
217+
}
210218
}
211219

212220
private void showExitConfirmDialog() {

app/src/main/java/org/autojs/autojs/ui/edit/ViewSampleActivity.java

Lines changed: 9 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,11 @@
55
import android.content.Intent;
66
import android.content.IntentFilter;
77
import android.os.Bundle;
8+
89
import com.google.android.material.snackbar.Snackbar;
10+
911
import androidx.appcompat.app.AppCompatActivity;
12+
1013
import android.util.SparseArray;
1114
import android.view.Menu;
1215
import android.view.MenuItem;
@@ -15,13 +18,16 @@
1518
import com.stardust.app.OnActivityResultDelegate;
1619
import com.stardust.autojs.engine.JavaScriptEngine;
1720
import com.stardust.autojs.execution.ScriptExecution;
21+
1822
import org.autojs.autojs.R;
1923
import org.autojs.autojs.autojs.AutoJs;
2024
import org.autojs.autojs.model.sample.SampleFile;
2125
import org.autojs.autojs.ui.BaseActivity;
2226
import org.autojs.autojs.ui.common.ScriptOperations;
27+
2328
import com.stardust.theme.ThemeColorManager;
2429
import com.stardust.util.SparseArrayEntries;
30+
2531
import org.autojs.autojs.ui.widget.ToolbarMenuItem;
2632

2733
import butterknife.ButterKnife;
@@ -99,12 +105,9 @@ void edit() {
99105
new ScriptOperations(this, mView)
100106
.importSample(mSample)
101107
.observeOn(AndroidSchedulers.mainThread())
102-
.subscribe(new Consumer<String>() {
103-
@Override
104-
public void accept(@NonNull String path) throws Exception {
105-
EditActivity.editFile(ViewSampleActivity.this, path);
106-
finish();
107-
}
108+
.subscribe(path -> {
109+
EditActivity.editFile(ViewSampleActivity.this, path, false);
110+
finish();
108111
});
109112
}
110113

app/src/main/java/org/autojs/autojs/ui/main/MainActivity.java

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,9 @@
44
import android.content.Intent;
55
import android.content.pm.PackageManager;
66
import android.os.Bundle;
7+
78
import androidx.annotation.NonNull;
9+
810
import com.google.android.material.floatingactionbutton.FloatingActionButton;
911

1012
import androidx.core.view.GravityCompat;
@@ -65,7 +67,6 @@
6567
@EActivity(R.layout.activity_main)
6668
public class MainActivity extends BaseActivity implements OnActivityResultDelegate.DelegateHost, BackPressedHandler.HostActivity, PermissionRequestProxyActivity {
6769

68-
6970
public static class DrawerOpenEvent {
7071
static DrawerOpenEvent SINGLETON = new DrawerOpenEvent();
7172
}
@@ -138,7 +139,7 @@ private void registerBackPressHandlers() {
138139
}
139140

140141
private void checkPermissions() {
141-
checkPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE);
142+
checkPermission(Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE);
142143
}
143144

144145
private void showAccessibilitySettingPromptIfDisabled() {
@@ -180,8 +181,6 @@ private void setUpTabViewPager() {
180181
}
181182

182183
private void setUpViewPagerFragmentBehaviors() {
183-
184-
185184
mPagerAdapter.setOnFragmentInstantiateListener((pos, fragment) -> {
186185
((ViewPagerFragment) fragment).setFab(mFab);
187186
if (pos == mViewPager.getCurrentItem()) {

autojs/src/main/AndroidManifest.xml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@
99
<uses-permission android:name="android.permission.WAKE_LOCK"/>
1010
<uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES"/>
1111
<uses-permission android:name="android.permission.WRITE_SETTINGS"/>
12+
<uses-permission android:name="android.permission.WRITE_SECURE_SETTINGS"/>
1213

1314
<application
1415
>

autojs/src/main/java/com/stardust/autojs/core/graphics/ScriptCanvasView.kt

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -56,7 +56,6 @@ class ScriptCanvasView(context: Context, private val mScriptRuntime: ScriptRunti
5656
while (mDrawing) {
5757
canvas = lockCanvas()
5858
scriptCanvas.setCanvas(canvas)
59-
// scriptCanvas.drawColor(Color.WHITE);
6059
emit("draw", scriptCanvas, this@ScriptCanvasView)
6160
unlockCanvasAndPost(canvas)
6261
canvas = null
10.7 MB
Binary file not shown.

project-versions.json

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
{
2-
"appVersionCode": 455,
3-
"appVersionName": "4.1.0 Alpha5",
2+
"appVersionCode": 460,
3+
"appVersionName": "4.1.1 Alpha",
44
"target": 28,
55
"mini": 17,
66
"compile": 28,

0 commit comments

Comments
 (0)