- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的应用程序有一个大问题。
当它关闭(不在后台)并收到广播时,该应用将打开并置于前台。
这很烦人。
我将相同广播接收器的代码放在一个空项目中,问题没有出现。
upper 代码在接收器被存在错误的应用程序激活时复制到 AndroidMonitor 中。
应用没有问题的下。
09-18 12:28:34.893 26455-26455/? I/art: Late-enabling -Xcheck:jni
09-18 12:28:34.960 26455-26455/agm.fisioapp W/System: ClassLoader referenced unknown path: /data/app/agm.fisioapp-2/lib/arm
09-18 12:28:35.063 26455-26455/agm.fisioapp W/art: Before Android 4.1, method android.graphics.PorterDuffColorFilter android.support.graphics.drawable.VectorDrawableCompat.updateTintFilter(android.graphics.PorterDuffColorFilter, android.content.res.ColorStateList, android.graphics.PorterDuff$Mode) would have incorrectly overridden the package-private method in android.graphics.drawable.Drawable
09-18 12:28:35.141 26455-26455/agm.fisioapp D/AutoManageHelper: starting AutoManage for client 0 false false
09-18 12:28:35.160 26455-26455/agm.fisioapp D/AutoManageHelper: onStart true {0=com.google.android.gms.internal.zzaaa$zza@945134}
09-18 12:28:35.206 26455-26499/agm.fisioapp I/Adreno-EGL: <qeglDrvAPI_eglInitialize:379>: EGL 1.4 QUALCOMM build: Nondeterministic_AU_msm8974_LA.BF.1.1.3_RB1__release_AU (Ia6c73e7530)
OpenGL ES Shader Compiler Version: E031.29.00.00
Build Date: 12/04/15 Fri
Local Branch: mybranch17080070
Remote Branch: quic/LA.BF.1.1.3_rb1.5
Local Patches: NONE
Reconstruct Branch: NOTHING
09-18 12:28:35.215 26455-26499/agm.fisioapp I/OpenGLRenderer: Initialized EGL, version 1.4
09-18 12:28:35.215 26455-26499/agm.fisioapp D/OpenGLRenderer: Swap behavior 1
09-18 12:28:35.217 26455-26499/agm.fisioapp W/Adreno-ES20: <get_gpu_clk:229>: open failed: errno 13
09-18 12:28:35.250 26455-26491/agm.fisioapp W/System: ClassLoader referenced unknown path: /system/framework/tcmclient.jar
09-18 12:28:35.252 26455-26491/agm.fisioapp D/NetworkSecurityConfig: No Network Security Config specified, using platform default
---------------------------------------------------------------------------------------
09-18 12:30:35.063 28050-28050/? I/art: Late-enabling -Xcheck:jni
09-18 12:30:35.086 28050-28057/? I/art: Debugger is no longer active
09-18 12:30:35.086 28050-28057/? I/art: Starting a blocking GC Instrumentation
09-18 12:30:35.104 28050-28050/? W/System: ClassLoader referenced unknown path: /data/app/com.javatechig.alarmservice-2/lib/arm
09-18 12:30:35.113 28050-28050/? D/prova: prova
这是接收者的代码:
public class CreatoreNotificaAllenamento extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent in = new Intent(context, MainActivity.class);
long[] pattern = {0, 500, 1};
PendingIntent pi = PendingIntent.getActivity(context, 01234, in, PendingIntent.FLAG_UPDATE_CURRENT);
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(context)
.setSmallIcon(R.drawable.icona_notifica)
.setContentTitle(context.getString(R.string.notifica_titolo_ricordo_allenamnto))
.setContentText(context.getString(R.string.testo_notifica))
.setVibrate(pattern)
.setAutoCancel(true);
mBuilder.setContentIntent(pi);
mBuilder.setDefaults(Notification.DEFAULT_SOUND);
NotificationManager mNotificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
mNotificationManager.notify(0, mBuilder.build());
}
这是我用来启动 AlarmService 的方法:
public static void setAlarm(Context c, Date data) {
AlarmManager alarmMgr = (AlarmManager) c.getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(c, CreatoreNotificaAllenamento.class);
PendingIntent pi = PendingIntent.getBroadcast(c, 0, intent, 0);
if(System.currentTimeMillis() > data.getTime()) {
Calendar cal = Calendar.getInstance();
cal.setTime(data);
cal.add(Calendar.DAY_OF_YEAR, 1);
data = cal.getTime();
}
alarmMgr.setInexactRepeating(AlarmManager.RTC_WAKEUP, data.getTime(),
1000*60*2, pi);
}
list :
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="agm.fisioapp">
/*
PERMESSI
*/
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<application
android:name=".App"
android:allowBackup="true"
android:icon="@mipmap/icona"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity
android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".Algoritmi.CreatoreNotificaAllenamento" />
<receiver android:name=".Algoritmi.SampleBootReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
/*
other activities
*/
</application>
App.java代码:
public class App extends Application {
@Override
public void onCreate() {
super.onCreate();
SharedPreferences primoAvvio = getSharedPreferences(Costanti.preferenzeMiste, MODE_PRIVATE);
if(!primoAvvio.contains("primoAvvio")) {
// se entro qua vuol dire che è il primo avvio dell'app
try {
caricaDatiSulDB();
SharedPreferences.Editor editor = primoAvvio.edit();
editor.putBoolean("primoAvvio", false);
editor.apply();
} catch (IOException e) {
e.printStackTrace();
}
} else try{
MainModel model = new MainModel(getApplicationContext());
if(controlloVersione()) {
model.cancellaDati();
caricaDatiSulDB();
}
} catch (IOException ex){
ex.printStackTrace();
}
// Controlla se l'utente è loggato.
SharedPreferences prefs = getSharedPreferences(Costanti.preferenzeDatiUtente, MODE_PRIVATE);
if(!prefs.contains("idUtente") && prefs.getBoolean("isGoogle",false) == false){
startActivity(new Intent(getApplicationContext(), LoginActivity.class)
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK));
} else {
// se esistono dei dati di login salvati eseguilo in background.
startActivity(new Intent(getApplicationContext(), BackgroundLogin.class)
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK));
}
}
/**
* Controlla se va fatto l'aggiornamento degli es/patologie/ecc..
* @return true se va aggiornato, false altrimenti
*/
private boolean controlloVersione() throws IOException {
BufferedReader in = new BufferedReader(new InputStreamReader(getAssets().open("version.txt")));
float version = Float.parseFloat(in.readLine());
SharedPreferences preferences = getSharedPreferences(Costanti.preferenzeMiste, MODE_PRIVATE);
if(version != preferences.getFloat("versione", 0)){
SharedPreferences.Editor editor = preferences.edit();
editor.putFloat("versione", version);
editor.apply();
return true;
} else
return false;
}
private void caricaDatiSulDB() throws IOException {
MainModel model = new MainModel(getApplicationContext());
// carico i dati nel db locale
model.eserciziToDB(model.lettura(FILE_ESERCIZI));
model.patologieToDB(model.lettura(FILE_PATOLOGIE));
model.protocolliToDB(model.lettura(FILE_PROTOCOLLI));
model.faseToDB(model.lettura(FILE_FASI));
model.defaultToDB(model.lettura(FILE_ESERCIZIO_FASI));
model.consigliToDB(model.lettura(FILE_CONSIGLIO));
model.specificheToDB(model.lettura(FILE_SPECIFICHE));
model.curiositaToDB(model.lettura(FILE_CURIOSITA));
}
最佳答案
正如我所怀疑的。当您的应用未运行时,并且触发了 BroadcastReceiver
(例如,在启动时),Android 会为您的应用创建一个新的操作系统进程,并创建您的自定义 Application< 的新实例
类,并在该实例上调用 onCreate()
。在您的代码中,在您的自定义 Application
类的 onCreate()
中调用 startActivity()
。当然,这会将您的应用带到前台并显示已启动的 Activity
。您可能不希望这种情况发生。
您可能应该从自定义 Application
类的 onCreate()
中删除 startActivity()
调用,并将它们放在其他地方。
关于android - 应用程序在收到广播时自动打开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46277426/
我正在通过 labrepl 工作,我看到了一些遵循此模式的代码: ;; Pattern (apply #(apply f %&) coll) ;; Concrete example user=> (a
我从未向应用商店提交过应用,但我会在不久的将来提交。 到目前为止,我对为 iPhone 而非 iPad 进行设计感到很自在。 我了解,通过将通用PAID 应用放到应用商店,客户只需支付一次就可以同时使
我有一个应用程序,它使用不同的 Facebook 应用程序(2 个不同的 AppID)在 Facebook 上发布并显示它是“通过 iPhone”/“通过 iPad”。 当 Facebook 应用程序
我有一个要求,我们必须通过将网站源文件保存在本地 iOS 应用程序中来在 iOS 应用程序 Webview 中运行网站。 Angular 需要服务器来运行应用程序,但由于我们将文件保存在本地,我们无法
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
假设我有一个安装在用户设备上的 Android 应用程序 A,我的应用程序有一个 AppWidget,我们可以让其他 Android 开发人员在其中以每次安装成本为基础发布他们的应用程序推广广告。因此
Secrets of the JavaScript Ninja中有一个例子它提供了以下代码来绕过 JavaScript 的 Math.min() 函数,该函数需要一个可变长度列表。 Example:
当我分别将数组和对象传递给 function.apply() 时,我得到 NaN 的 o/p,但是当我传递对象和数组时,我得到一个数字。为什么会发生这种情况? 由于数组也被视为对象,为什么我无法使用它
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章ASP转换格林威治时间函数DateDiff()应用由作者收集整理,如果你
我正在将列表传递给 map并且想要返回一个带有合并名称的 data.frame 对象。 例如: library(tidyverse) library(broom) mtcars %>% spl
我有一个非常基本的问题,但我不知道如何实现它:我有一个返回数据框,其中每个工具的返回值是按行排列的: tmp<-as.data.frame(t(data.frame(a=rnorm(250,0,1)
我正在使用我的 FB 应用创建群组并邀请用户加入我的应用群组,第一次一切正常。当我尝试创建另一个组时,出现以下错误: {"(OAuthException - #4009) (#4009) 在有更多用户
我们正在开发一款类似于“会说话的本”应用程序的 child 应用程序。它包含大量用于交互式动画的 JPEG 图像序列。 问题是动画在 iPad Air 上播放正常,但在 iPad 2 上播放缓慢或滞后
我关注 clojure 一段时间了,它的一些功能非常令人兴奋(持久数据结构、函数式方法、不可变状态)。然而,由于我仍在学习,我想了解如何在实际场景中应用,证明其好处,然后演化并应用于更复杂的问题。即,
我开发了一个仅使用挪威语的应用程序。该应用程序不使用本地化,因为它应该仅以一种语言(挪威语)显示。但是,我已在 Info.plist 文件中将“本地化 native 开发区域”设置为“no”。我还使用
读完 Anthony's response 后上a style-related parser question ,我试图说服自己编写单体解析器仍然可以相当紧凑。 所以而不是 reference ::
multicore 库中是否有类似 sapply 的东西?还是我必须 unlist(mclapply(..)) 才能实现这一点? 如果它不存在:推理是什么? 提前致谢,如果这是一个愚蠢的问题,我们深表
我喜欢在窗口中弹出结果,以便更容易查看和查找(例如,它们不会随着控制台继续滚动而丢失)。一种方法是使用 sink() 和 file.show()。例如: y <- rnorm(100); x <- r
我有一个如下所示的 spring mvc Controller @RequestMapping(value="/new", method=RequestMethod.POST) public Stri
我正在阅读 StructureMap关于依赖注入(inject),首先有两部分初始化映射,具体类类型的接口(interface),另一部分只是实例化(请求实例)。 第一部分需要配置和设置,这是在 Bo
我是一名优秀的程序员,十分优秀!