Android Studio is not supported JCEF 安卓应用开发

All the products on all the supported platforms already have 64-bit JetBrains Runtime 21 bundled and it will be used by default to run the IDE. If you need to change the runtime to a different version, see below. Please note that all the current IDE versions require at least Java 17 version to run. Our IDEs will not run on the older Java versions like Java 8 or 11.

All platforms: download and install JetBrains Runtime via Choose Boot Java Runtime for the IDE action
Start the IDE, use Help | Find Action (Ctrl+Shift+A or Cmd+Shift+A on Mac), type "Choose Boot Java Runtime for the IDE", press Enter.
Select the version to install, the higher the number after b, the more recent is the version. It makes sense to install the most recent version or the version you were asked to try by JetBrains staff. Installing old runtime versions may render your IDE unusable or introduce new issues.
Click the OK button and wait until the file with JetBrains Runtime is downloaded and configured.
Restart the IDE to try the new runtime.
Verify via About dialog that the new runtime is used. Notice the vendor (should be JetBrains s.r.o) and the release number (should correspond to the number after b in the file you've downloaded).
If the JDK version in the About dialog doesn't match or didn't change, see below. Most likely, you have an environment variable configured which has the priority over the .jdk file. Remove any environment variables affecting IDE runtime selection and restart.
All platforms: Add Custom Runtime
Follow the steps from the section above to open the Choose Boot Java Runtime for the IDE dialog.
Use the Add Custom Runtime option
Select one of the already installed JDK 21 options or click Add JDK
To add a new JDK specify the home folder of the Java 21 installation on your disk
This option is useful to check if the issue you might have is specific to JetBrains Runtime or is common to this Java version from all the vendors. It helps to isolate and fix issues with JetBrains Runtime or workaround problems as you can continue working until the issue is resolved.


new 发布于 2025-2-26 03:11

Android 各版本对应的SDK版本号 安卓应用开发

Android 各版本对应的SDK版本号
Android版本号 SDK版本号 版本号名称
9 28 Build.VERSION_CODES.P
8.1 27 Build.VERSION_CODES.O_MR1
8.0 26 Build.VERSION_CODES.O
7.1 25 Build.VERSION_CODES.N_MR1
7.0 24 Build.VERSION_CODES.N
6.0 23 Build.VERSION_CODES.M
5.1 22 Build.VERSION_CODES.LOLLIPOP_MR1
5.0 21 Build.VERSION_CODES.LOLLIPOP
4.4 19 Build.VERSION_CODES.KITKAT
4.3 18 Build.VERSION_CODES.JELLY_BEAN_MR2
4.2.x 17 Build.VERSION_CODES.JELLY_BEAN_MR1
4.1.x 16 Build.VERSION_CODES.JELLY_BEAN
4.0.3 -
4.0.4 15 Build.VERSION_CODES.ICE_CREAM_SANDWICH_MR1
2.3.3 -
2.3.7 10 Build.VERSION_CODES.GINGERBREAD_MR1


new 发布于 2024-8-21 02:17

Android 权限 安卓应用开发

Android 权限

标签: 权限

new 发布于 2024-4-23 04:17

新版本Android Studio中logcat无设备问题 安卓应用开发

升级sdk platform-tools以升级adb版本

标签: adb logcat

new 发布于 2024-2-2 06:01

RemoteServiceException: Bad notification for startForeground: 安卓应用开发

检查manifest里application标签的android:icon="@mipmap/ic_launcher",设置一个icon


new 发布于 2022-11-4 00:44

keystore文件转换成jks 安卓应用开发

keystore文件转换成jks文件:


keytool -v -importkeystore -srckeystore D:\android.keystore -srcstoretype PKCS12 -destkeystore android.jks -deststoretype JKS



new 发布于 2022-3-31 06:14

解决android studio 的Codeglance插件不显示问题 安卓应用开发

在Android studio中 file --> settings-->搜索codeglance 然后在other settings里 去掉disabled后的勾。


new 发布于 2021-11-18 02:21

Intent 启动Activity的各种FLAG解析 安卓应用开发

一、与Activity启动行为相关的就是它的启动模式,Standard、SingleTop、SingleTask、SingleInstance

standard mode

标准模式,启动直接加到栈顶,销毁后移除。

singletop mode

栈顶唯一,如果栈顶存在就不会重复启动,保证栈顶不会有两个相同的Activtiy

singletask mode

栈内唯一,如果栈内存在,再次启动时会自动把它上面的其他Activity全部清除(调用onDestroy)

singleinstance mode

独占一栈,启动时会建立新栈切换过去,如果启动了普通Activity又会切换回原来的共享栈(新栈仍然存在,会在栈内唯一的Activity结束时关闭)

二、复杂的控制Activity行为的方式,给启动Activity的Intent添加flag,使用 Intent.addFlags(int flags) 

        Intent.FLAG_ACTIVITY_BROUGHT_TO_FRONT,
        Intent.FLAG_ACTIVITY_CLEAR_TASK,
        Intent.FLAG_ACTIVITY_CLEAR_TOP,
        Intent.FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET,
        Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS,
        Intent.FLAG_ACTIVITY_FORWARD_RESULT,
        Intent.FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY,
        Intent.FLAG_ACTIVITY_LAUNCH_ADJACENT,
        Intent.FLAG_ACTIVITY_MULTIPLE_TASK,
        Intent.FLAG_ACTIVITY_NEW_DOCUMENT,
        Intent.FLAG_ACTIVITY_NEW_TASK,
        Intent.FLAG_ACTIVITY_NO_ANIMATION,
        Intent.FLAG_ACTIVITY_NO_HISTORY,
        Intent.FLAG_ACTIVITY_NO_USER_ACTION,
        Intent.FLAG_ACTIVITY_PREVIOUS_IS_TOP,
        Intent.FLAG_ACTIVITY_REORDER_TO_FRONT,
        Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED,
        Intent.FLAG_ACTIVITY_RETAIN_IN_RECENTS,
        Intent.FLAG_ACTIVITY_SINGLE_TOP,
        Intent.FLAG_ACTIVITY_TASK_ON_HOME,

1. FLAG_ACTIVITY_CLEAR_TASK

1. 本flag能造成在新活动启动前,与新活动关联的任务被清空。也就是说,新活动成为新任务的根,旧的活动都被结束了。本flag只能与FLAG_ACTIVITY_NEW_TASK联合使用。


2. FLAG_ACTIVITY_CLEAR_TOP

 1. 新活动已在当前任务中时,在新活动上面的活动会被关闭,新活动不会重新启动,只会接收new intent。
 2. 新活动已在任务最上面时:如果启动模式是"multiple" (默认的),并且没添加FLAG_ACTIVITY_SINGLE_TOP,那么活动会被销毁重新创建;如果启动模式是其他的,或者添加了FLAG_ACTIVITY_SINGLE_TOP,那么只会调用活动的onNewIntent()。
 3. 跟FLAG_ACTIVITY_NEW_TASK联合使用效果很好:如果用于启动一个任务中的根活动,会把该任务移到前面并清空至root状态。这特别有用,比如用于从notification manager中启动活动。


3. FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET

已废弃。API 21后用FLAG_ACTIVITY_NEW_DOCUMENT。


4. FLAG_ACTIVITY_MULTIPLE_TASK

 1. 用于创建一个新任务,并启动一个活动放进去;

总是跟FLAG_ACTIVITY_NEW_DOCUMENT或者FLAG_ACTIVITY_NEW_TASK一起使用;

单独用FLAG_ACTIVITY_NEW_DOCUMENT或者FLAG_ACTIVITY_NEW_TASK时,会在已存在的任务中寻找匹配的Intent,找不到才会创建一个新任务;

使用了本flag不会寻找匹配的Intent,无条件创建一个新任务。

  1. 用了FLAG_ACTIVITY_NEW_TASK就不要用本flag,除非你启动的是应用的launcher。 跟FLAG_ACTIVITY_NEW_TASK联合使用能防止把已存在的任务移到前面,会为新活动创建一个新任务,无论已存在的任务中有没有新活动。
  2. 因为默认安卓系统中没有提供可视化的任务管理,所以你不应该使用本flag,除非给用户提供可以回到其他任务的方法。
  3. 单独用本flag而不用FLAG_ACTIVITY_NEW_DOCUMENT或者FLAG_ACTIVITY_NEW_TASK是无效的。


    5. FLAG_ACTIVITY_NEW_DOCUMENT

     1. 本flag会给启动的活动开一个新的任务记录。使用了本flag或documentLaunchMode属性时,相同活动的多实例会在最近任务列表中产生不同的记录。

     2. 使用本flag比使用documentLaunchMode属性更好,因为documentLaunchMode属性会跟活动绑定,而flag只在需要时添加。

     3. 注意本flag的默认词义,活动销毁后最近任务列表中的入口不会移除。这跟使用FLAG_ACTIVITY_NEW_TASK不一样,后者活动销毁后入口会马上移除。你可以用FLAG_ACTIVITY_RETAIN_IN_RECENTS改变这个行为。

     4. 本flag可以跟FLAG_ACTIVITY_MULTIPLE_TASK联合使用。单独使用时跟manifest活动中定义documentLaunchMode="intoExisting"效果相同,联合使用时跟manifest活动中定义documentLaunchMode="always"效果相同。


    6. FLAG_ACTIVITY_NEW_TASK

     1. 新活动会成为历史栈中的新任务(一组活动)的开始。

     2. 通常用于具有"launcher"行为的活动:让用户完成一系列事情,完全独立于之前的活动。

     3. 如果新活动已存在于一个为它运行的任务中,那么不会启动,只会把该任务移到屏幕最前。

     4. 如果新活动要返回result给启动自己的活动,就不能用这个flag。


    7. FLAG_ACTIVITY_NO_ANIMATION

     1. 本flag会阻止系统展示活动的当前状态到另一个状态之间的转移动画。这并不意味着永远没有动画 -- 如果另一项活动的改变在当前展示的活动启动前发生并且没有使用本flag,那么动画还会展示。当你要进行一系列活动操作,但是用户看到的动画不应该由第一项改变来驱动,而是由下一项。


    8. FLAG_ACTIVITY_NO_HISTORY

     1. 新活动不会保留在历史栈中,一旦用户切换到其他页面,新活动会马上销毁。

     2. 旧活动的onActivityResult()方法永远不会被触发。


    9. FLAG_ACTIVITY_REORDER_TO_FRONT

     1. 如果新活动已在任务中,用本flag启动会将它移到任务的历史栈的前面。

     2. 如果用了FLAG_ACTIVITY_CLEAR_TOP,本flag就无效。


    10. FLAG_ACTIVITY_RETAIN_IN_RECENTS

     1. 默认情况下由FLAG_ACTIVITY_NEW_DOCUMENT创建的新纪录,用户关闭时(按返回键或其他方式结束)它在最近任务中的入口会被移除。如果你想保留入口,就用本flag。

     2. 接收的活动可以用autoRemoveFromRecents属性或者调用Activity.finishAndRemoveTask()来覆盖本请求。


    11. FLAG_ACTIVITY_SINGLE_TOP

     1. 新活动已存在历史栈的顶端时就不会重新启动。


    12. FLAG_ACTIVITY_FORWARD_RESULT

     1. (当前活动由源活动启动)本intent从当前活动启动新活动时,源活动的接收目标会从当前活动转移为新活动。新活动调用setResult的数据会传送给源活动。

      

    13. FLAG_ACTIVITY_PREVIOUS_IS_TOP

     1. 本intent从当前活动启动新活动时,当前活动不会被视为顶端活动,不管是决定传intent给顶端还是启动新活动。新活动被当做顶端活动使用,假设当前活动立即销毁了。


    14. FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS

     1. 新活动不会保存在最近启动的活动列表中。


    15. FLAG_ACTIVITY_BROUGHT_TO_FRONT

    1. 本flag一般不由应用代码设置,singleTask模式时系统会给你设置。


    16. FLAG_ACTIVITY_RESET_TASK_IF_NEEDED

     1. 新活动在新任务中启动或者被放到一个已存在任务的顶端时,会被当做任务的前门来启动。这会导致任何相关性的活动在适当状态下需要拥有这个任务(无论移动活动到它里面或者是移走),或者在需要时简单地重置任务到初始状态。

      

    17. FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY

     1. 本flag一般不由应用代码设置,活动从历史栈中启动(长按home键)时系统会给你设置。

      

    18. FLAG_ACTIVITY_NO_USER_ACTION

     1. 本flag会阻止当前最前面活动的onUserLeaveHint回调,在它被新启动的活动造成paused状态时。

     2. 通常,一个活动在受到用户操作而从前面移走的时候会调用上面的回调。该回调标志着活动生命周期中的一个点,在该点活动会隐藏它想要显示的”直到用户看到“的东西,比如闪烁的LED灯。

     3. 如果一个活动曾经由非用户驱动的事件比如来电或闹钟启动,应该在startActivity中添加本flag,以保证暂停时活动知道用户并没有看到通知。

      

    19. FLAG_ACTIVITY_TASK_ON_HOME

     1. 本flag会造成新的启动任务放在当前主页活动任务(如果有的话)的顶端。也就是说,在任务中按返回键总是会回到主页,即使上一个用户看到的活动不是主页。本flag只能与FLAG_ACTIVITY_NEW_TASK联合使用。

      

    20. FLAG_ACTIVITY_LAUNCH_ADJACENT

     1. 本flag只在分屏多窗口模式下使用。新活动会显示在旧活动旁边。本flag只能跟FLAG_ACTIVITY_NEW_TASK联合使用。并且如果你想创建一个已存在活动的新实例,那么要设置FLAG_ACTIVITY_MULTIPLE_TASK。

     




标签: flag

new 发布于 2021-9-27 05:38

android 7.0 pm install 失败问题 安卓应用开发

android 7.0 pm install 失败问题

这两天,把app内置成系统文件或者系统签名取得系统权限,发现使用pm install path在低版本上可行,在高版本就安装失败

抛出 NullPointException,

pm install -i packagename path

添加权限

<uses-permission android:name="android.permission.INSTALL_PACKAGES" />

标签: Android pm

new 发布于 2021-7-23 08:29