Q
quidproquo
Neues Mitglied
- 0
Ich will dass die Klasse mit BroadcastReceiver erst eine Internet-Seite mit jsoup ließt und dann (etwas checkt und dann) eine notification mit der AsyncTask-Klasse entsendet. Weil der Part mit jsoup ein AsyncTask erfordert, muss der Part mit der notification in den onPostExecute-Bereich rein, denke ich.
Wenn der notification-Part nicht innerhalb des AsyncTask-Codes ist, funktioniert die Notification an sich, jedoch ist der Part mit jsoup da ausgelassen.
Das ist der Code der Klasse NotificationClass bis jetzt:
public class NotificationClass extends BroadcastReceiver{
Context specialContext;
int MID = 1;
long when = System.currentTimeMillis();
Uri alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
@override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
new loadText().execute();
}
public class loadText extends AsyncTask<Void, Void, Void>
{
String siteText;
@override
protected Void doInBackground(Void... params) {
Connection.Response res = null;
try {
res = Jsoup.connect("HPG-Speyer | Main / Vertretungsplan") // Link der Hauptseite, wo auch der Login ist
.data("authid", "22101999AzaKur", "authpw", "451d28") // Hier wären dann die Daten eingetragen
.method(Connection.Method.POST)
.execute();
} catch (Exception e) {
e.printStackTrace();
}
try {
Document doc = res.parse();
} catch (Exception e) {
e.printStackTrace();
}
String sessionId = res.cookie("PHPSESSID"); // Name des Cookies
Document doc2 = null;
try {
doc2 = Jsoup.connect("HPG-Speyer | Main / Vertretungsplan") // das wäre der Link zu den Feldern
.cookie("PHPSESSID", sessionId)
.get();
siteText = doc2.text();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
@override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
NotificationManager notificationManager = (NotificationManager) specialContext
.getSystemService(Context.NOTIFICATION_SERVICE);
Intent notificationIntent = new Intent(specialContext, MainActivity.class);
notificationIntent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
PendingIntent pendingIntent = PendingIntent.getActivity(specialContext, 0,
notificationIntent, PendingIntent.FLAG_UPDATE_CURRENT);
NotificationCompat.Builder mNotifyBuilder = (NotificationCompat.Builder) new NotificationCompat.Builder(
specialContext).setSmallIcon(R.mipmap.ic_launcher)
.setContentTitle("Alarm Fired")
.setContentText("Events To be PErformed").setSound(alarmSound)
.setAutoCancel(true).setWhen(when)
.setContentIntent(pendingIntent)
.setVibrate(new long[]{1000, 1000, 1000, 1000, 1000});
if (siteText.contains("something")) {
notificationManager.notify(MID, mNotifyBuilder.build());
MID++;
}
}
}
}
logcat:
02-11 12:47:40.626 5413-5413/? I/art: Not late-enabling -Xcheck:jni (already on)
02-11 12:47:40.626 5413-5413/? W/art: Unexpected CPU variant for X86 using defaults: x86
02-11 12:47:40.708 5413-5413/de.kurt.vertretungsplan W/System: ClassLoader referenced unknown path: /data/app/de.kurt.vertretungsplan-1/lib/x86
02-11 12:47:40.711 5413-5413/de.kurt.vertretungsplan I/InstantRun: Instant Run Runtime started. Android package is de.kurt.vertretungsplan, real application class is null.
02-11 12:47:40.988 5413-5413/de.kurt.vertretungsplan W/System: ClassLoader referenced unknown path: /data/app/de.kurt.vertretungsplan-1/lib/x86
02-11 12:47:41.061 5413-5413/de.kurt.vertretungsplan 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
02-11 12:47:41.125 5413-5445/de.kurt.vertretungsplan D/NetworkSecurityConfig: No Network Security Config specified, using platform default
02-11 12:47:41.218 5413-5447/de.kurt.vertretungsplan I/OpenGLRenderer: Initialized EGL, version 1.4
02-11 12:47:41.218 5413-5447/de.kurt.vertretungsplan D/OpenGLRenderer: Swap behavior 1
02-11 12:47:41.248 5413-5447/de.kurt.vertretungsplan E/EGL_emulation: tid 5447: eglSurfaceAttrib(1174): error 0x3009 (EGL_BAD_MATCH)
02-11 12:47:41.248 5413-5447/de.kurt.vertretungsplan W/OpenGLRenderer: Failed to set EGL_SWAP_BEHAVIOR on surface 0x9c73fe80, error=EGL_BAD_MATCH
Wie ich den crash bemerkt habe:
Ich habe die Zeit bei der der Alarm von der MainActivity aus ausgelöst wird auf relativ nahe Zukunft gestellt, dann die App mit dem virtuellen Gerät gestartet und beobachtet. Dann wenn theoretisch die notification kommt steht: "HPG Vertretungsplan has stopped".
Danke im Voraus.
Wenn der notification-Part nicht innerhalb des AsyncTask-Codes ist, funktioniert die Notification an sich, jedoch ist der Part mit jsoup da ausgelassen.
Das ist der Code der Klasse NotificationClass bis jetzt:
public class NotificationClass extends BroadcastReceiver{
Context specialContext;
int MID = 1;
long when = System.currentTimeMillis();
Uri alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
@override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
new loadText().execute();
}
public class loadText extends AsyncTask<Void, Void, Void>
{
String siteText;
@override
protected Void doInBackground(Void... params) {
Connection.Response res = null;
try {
res = Jsoup.connect("HPG-Speyer | Main / Vertretungsplan") // Link der Hauptseite, wo auch der Login ist
.data("authid", "22101999AzaKur", "authpw", "451d28") // Hier wären dann die Daten eingetragen
.method(Connection.Method.POST)
.execute();
} catch (Exception e) {
e.printStackTrace();
}
try {
Document doc = res.parse();
} catch (Exception e) {
e.printStackTrace();
}
String sessionId = res.cookie("PHPSESSID"); // Name des Cookies
Document doc2 = null;
try {
doc2 = Jsoup.connect("HPG-Speyer | Main / Vertretungsplan") // das wäre der Link zu den Feldern
.cookie("PHPSESSID", sessionId)
.get();
siteText = doc2.text();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
@override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
NotificationManager notificationManager = (NotificationManager) specialContext
.getSystemService(Context.NOTIFICATION_SERVICE);
Intent notificationIntent = new Intent(specialContext, MainActivity.class);
notificationIntent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
PendingIntent pendingIntent = PendingIntent.getActivity(specialContext, 0,
notificationIntent, PendingIntent.FLAG_UPDATE_CURRENT);
NotificationCompat.Builder mNotifyBuilder = (NotificationCompat.Builder) new NotificationCompat.Builder(
specialContext).setSmallIcon(R.mipmap.ic_launcher)
.setContentTitle("Alarm Fired")
.setContentText("Events To be PErformed").setSound(alarmSound)
.setAutoCancel(true).setWhen(when)
.setContentIntent(pendingIntent)
.setVibrate(new long[]{1000, 1000, 1000, 1000, 1000});
if (siteText.contains("something")) {
notificationManager.notify(MID, mNotifyBuilder.build());
MID++;
}
}
}
}
logcat:
02-11 12:47:40.626 5413-5413/? I/art: Not late-enabling -Xcheck:jni (already on)
02-11 12:47:40.626 5413-5413/? W/art: Unexpected CPU variant for X86 using defaults: x86
02-11 12:47:40.708 5413-5413/de.kurt.vertretungsplan W/System: ClassLoader referenced unknown path: /data/app/de.kurt.vertretungsplan-1/lib/x86
02-11 12:47:40.711 5413-5413/de.kurt.vertretungsplan I/InstantRun: Instant Run Runtime started. Android package is de.kurt.vertretungsplan, real application class is null.
02-11 12:47:40.988 5413-5413/de.kurt.vertretungsplan W/System: ClassLoader referenced unknown path: /data/app/de.kurt.vertretungsplan-1/lib/x86
02-11 12:47:41.061 5413-5413/de.kurt.vertretungsplan 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
02-11 12:47:41.125 5413-5445/de.kurt.vertretungsplan D/NetworkSecurityConfig: No Network Security Config specified, using platform default
02-11 12:47:41.218 5413-5447/de.kurt.vertretungsplan I/OpenGLRenderer: Initialized EGL, version 1.4
02-11 12:47:41.218 5413-5447/de.kurt.vertretungsplan D/OpenGLRenderer: Swap behavior 1
02-11 12:47:41.248 5413-5447/de.kurt.vertretungsplan E/EGL_emulation: tid 5447: eglSurfaceAttrib(1174): error 0x3009 (EGL_BAD_MATCH)
02-11 12:47:41.248 5413-5447/de.kurt.vertretungsplan W/OpenGLRenderer: Failed to set EGL_SWAP_BEHAVIOR on surface 0x9c73fe80, error=EGL_BAD_MATCH
Wie ich den crash bemerkt habe:
Ich habe die Zeit bei der der Alarm von der MainActivity aus ausgelöst wird auf relativ nahe Zukunft gestellt, dann die App mit dem virtuellen Gerät gestartet und beobachtet. Dann wenn theoretisch die notification kommt steht: "HPG Vertretungsplan has stopped".
Danke im Voraus.