- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以,我试图运行我的应用程序,它应该在第一次运行后显示通知。但是,它给了我这样的错误:
java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.pm.ApplicationInfo android.content.Context.getApplicationInfo()' on a null object reference
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.app.Notification$Builder.<init>(Notification.java:1951)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.support.v4.app.NotificationCompatApi21$Builder.<init>(NotificationCompatApi21.java:68)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.support.v4.app.NotificationCompat$NotificationCompatImplApi21.build(NotificationCompat.java:759)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.support.v4.app.NotificationCompat$Builder.build(NotificationCompat.java:1559)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at apps.skripsi.petvac.navigationmenu.MainMenu.createButtonNotification(MainMenu.java:383)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at apps.skripsi.petvac.navigationmenu.MainMenu$DataBinatangOperation.onPostExecute(MainMenu.java:235)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at apps.skripsi.petvac.navigationmenu.MainMenu$DataBinatangOperation.onPostExecute(MainMenu.java:145)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.os.AsyncTask.finish(AsyncTask.java:632)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.os.AsyncTask.access$600(AsyncTask.java:177)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5253)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:372)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:900)
12-10 12:01:03.512 3132-3132/apps.skripsi.petvac E/AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:695)
package apps.skripsi.petvac.navigationmenu;
import android.app.Activity;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.Intent;
import android.media.RingtoneManager;
import android.net.Uri;
import android.os.AsyncTask;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.design.widget.FloatingActionButton;
import android.support.v4.app.Fragment;
import android.support.v4.app.NotificationCompat;
import android.support.v4.app.TaskStackBuilder;
import android.support.v4.widget.SwipeRefreshLayout;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import org.apache.http.client.ClientProtocolException;
import org.joda.time.DateTime;
import org.joda.time.Days;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.IOException;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.Locale;
import apps.skripsi.petvac.MainMenu.MainMenuAdapter;
import apps.skripsi.petvac.R;
import apps.skripsi.petvac.addpetdata.MainAddPetDataActivity;
import apps.skripsi.petvac.Services.NotificationHandler;
import apps.skripsi.petvac.notification.NotificationButtonReceiver;
import apps.skripsi.petvac.notification.TestActivity;
import apps.skripsi.petvac.parser.JSONParser;
import apps.skripsi.petvac.petinformation.MainPetInformation;
import apps.skripsi.petvac.preference.PreferencesHelper;
/**
* Created by widi on 9/9/2015.
*/
public class MainMenu extends Fragment {
FloatingActionButton FAB;
JSONObject json;
JSONObject jsonObject;
PreferencesHelper pref;
ProgressDialog loading;
NotificationHandler NH;
ImageView iv;
ProgressDialog progress;
NotificationManager mNotificationManager;
SwipeRefreshLayout mSwipeRefreshLayout = null;
ListView list;
TextView tv;
String result;
String sisaWaktu;
String ID_USER, ID_BINATANG, NAMA_BINATANG, JENIS_BINATANG, FOTO_BINATANG, RAS_BINATANG, TANGGAL_VAKSIN, NAMA_VAKSIN, ID_DATA_WAKTU_VAKSINASI;
ArrayList<HashMap<String, String>> listBinatang = new ArrayList<HashMap<String, String>>();
public static String id_user = "id_user";
public static String id_binatang = "id_binatang";
public static String nama_binatang = "nama_binatang";
public static String jenis_binatang = "jenis_binatang";
public static String foto_binatang = "foto_binatang";
public static String ras_binatang = "ras_binatang";
public static String tanggal_vaksin = "tanggal_awal";
public static String nama_vaksin = "nama_vaksin";
public static String id_data_waktu_vaksinasi = "id_data_waktu_vaksinasi";
private Context context;
private static String url = "http://petvaccination.hol.es/api/data_menu_utama_vaksinasi.php";
private static String urlgambar = "http://petvaccination.hol.es/imgupload/uploadedimages/";
public MainMenu() {
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View v = inflater.inflate(R.layout.main_menu_fragment, container, false);
FAB = (FloatingActionButton) v.findViewById(R.id.buttonTambahData);
mSwipeRefreshLayout = (SwipeRefreshLayout) v.findViewById(R.id.activity_main_swipe_refresh_layout);
pref = new PreferencesHelper(getActivity().getBaseContext());
tv = (TextView) v.findViewById(R.id.textView);
list = (ListView) v.findViewById(R.id.list_hewan);
NH = NotificationHandler.getInstance(getActivity());
FAB.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent a = new Intent(getActivity(), MainAddPetDataActivity.class);
startActivity(a);
}
});
new DataBinatangOperation().execute(url);
mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
new DataBinatangOperation().execute(url);
updateList();
}
});
return v;
}
private void updateList() {
if (mSwipeRefreshLayout.isRefreshing()) {
mSwipeRefreshLayout.setRefreshing(false);
}
}
private class DataBinatangOperation extends AsyncTask<String, Void, String> {
MainMenuAdapter adapter = new MainMenuAdapter(MainMenu.this,
listBinatang);
@Override
protected String doInBackground(String... params) {
JSONArray json;
try {
result = JSONParser.getPage(url);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result;
}
@Override
protected void onPostExecute(String result) {
//updateList();
tv.setVisibility(View.GONE);
//mSwipeRefreshLayout.setRefreshing(false);
try {
System.out.print("result = " + result);
json = new JSONObject(result);
progress.dismiss();
JSONArray objek = json.getJSONArray("data_vaksinasi_menu");
for (int i = 0; i < objek.length(); i++) {
JSONObject jo = objek.getJSONObject(i);
ID_USER = jo.getString(id_user);
ID_BINATANG = jo.getString(id_binatang);
NAMA_BINATANG = jo.getString(nama_binatang);
JENIS_BINATANG = jo.getString(jenis_binatang);
FOTO_BINATANG = jo.getString(foto_binatang);
RAS_BINATANG = jo.getString(ras_binatang);
ID_DATA_WAKTU_VAKSINASI = jo.getString(id_data_waktu_vaksinasi);
TANGGAL_VAKSIN = jo.getString(tanggal_vaksin);
NAMA_VAKSIN = jo.getString(nama_vaksin);
if (pref.getPreferences("ID").equals(ID_USER)) {
if (jo.isNull(id_data_waktu_vaksinasi) && jo.isNull(tanggal_vaksin) && jo.isNull(nama_vaksin)) {
NAMA_VAKSIN = "belum ada data";
sisaWaktu = "";
}else {
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd", Locale.getDefault());
Calendar waktuSekarang = Calendar.getInstance();
Date date1 = waktuSekarang.getTime();
Date date2 = new Date();
date2 = formatter.parse(TANGGAL_VAKSIN);
if (date2.after(date1)) {
int days = Days.daysBetween(new DateTime(date1), new DateTime(date2)).getDays();
if (days > 7 && days <= 30) {
int weeks = days / 7;
sisaWaktu = String.valueOf(weeks) + " minggu";
} else if (days > 30 && days <= 365) {
int months = days / 30;
sisaWaktu = String.valueOf(months) + " bulan";
} else if (days > 365) {
int years = days / 365;
sisaWaktu = String.valueOf(years) + " tahun";
} else {
sisaWaktu = String.valueOf(days) + " hari";
if (days <= 5) {
createSimpleNotification(getActivity(), NAMA_BINATANG, sisaWaktu, ID_BINATANG);
}
}
} else if (date2.before(date1)) {
int days = Days.daysBetween(new DateTime(date2), new DateTime(date1)).getDays();
sisaWaktu = "lewat " + String.valueOf(days) + " hari";
createButtonNotification(context, NAMA_BINATANG, sisaWaktu, ID_BINATANG, ID_DATA_WAKTU_VAKSINASI);
} else if (date2.equals(date1)) {
sisaWaktu = "sekarang";
createButtonNotification(context, NAMA_BINATANG, sisaWaktu, ID_BINATANG, ID_DATA_WAKTU_VAKSINASI);
}
}
}
HashMap<String, String> map = new HashMap<String, String>();
map.put(id_binatang, ID_BINATANG);
map.put(nama_binatang, NAMA_BINATANG);
map.put(jenis_binatang, JENIS_BINATANG);
map.put(foto_binatang, urlgambar + FOTO_BINATANG);
map.put(ras_binatang, RAS_BINATANG);
map.put(tanggal_vaksin, sisaWaktu);
map.put(nama_vaksin, NAMA_VAKSIN);
if (pref.getPreferences("ID").equals(ID_USER)) {
listBinatang.add(map);
}
}
if(String.valueOf(listBinatang).equals("[]")){
tv.setVisibility(View.VISIBLE);
}
System.out.println("hasil list : " + String.valueOf(listBinatang));
System.out.println("adapter : " + String.valueOf(adapter));
list.setAdapter(adapter);
/*list.setVisibility(View.VISIBLE);*/
list.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long idx) {
HashMap<String, String> ambilid = new HashMap<String, String>();
ambilid = listBinatang.get(position);
Toast.makeText(getActivity(), "pindah halaman", Toast.LENGTH_SHORT).show();
Intent a = new Intent(getActivity(), MainPetInformation.class);
pref.savePreferences("IDB", ambilid.get(MainMenu.id_binatang));
pref.savePreferences("NAMAB", ambilid.get(MainMenu.nama_binatang));
pref.savePreferences("FOTOB", ambilid.get(MainMenu.foto_binatang));
pref.savePreferences("JENISB", ambilid.get(MainMenu.jenis_binatang));
pref.savePreferences("RASB", ambilid.get(MainMenu.ras_binatang));
startActivity(a);
}
});
} catch (JSONException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (ParseException e) {
e.printStackTrace();
}
// might want to change "executed" for the returned string passed
// into onPostExecute() but that is upto you
}
@Override
protected void onPreExecute() {
listBinatang.clear();
adapter.notifyDataSetChanged();
progress = ProgressDialog.show(getActivity(), "Please Wait",
"Loading Data", true);
}
@Override
protected void onProgressUpdate(Void... values) {
}
}
public void createSimpleNotification(Context context, String title, String content, String id) {
// Creates an explicit intent for an Activity
Intent resultIntent = new Intent(context, MainPetInformation.class);
resultIntent.putExtra("id", id);
context.startActivity(resultIntent);
mNotificationManager = (NotificationManager)context.getSystemService(getActivity().NOTIFICATION_SERVICE);
int IntID = Integer.valueOf(id);
Uri uri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
// Creating a artifical activity stack for the notification activity
TaskStackBuilder stackBuilder = TaskStackBuilder.create(context);
stackBuilder.addParentStack(TestActivity.class);
stackBuilder.addNextIntent(resultIntent);
// Pending intent to the notification manager
PendingIntent resultPending = PendingIntent.getActivity(context, IntID, resultIntent, 0);
// Building the notification
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(context)
.setSmallIcon(R.drawable.logo) // notification icon
.setContentTitle(title) // main title of the notification
.setContentText(content + " lagi")
.setSound(uri) // notification text
.setContentIntent(resultPending);// notification intent
// mId allows you to update the notification later on.
mNotificationManager.notify(IntID, mBuilder.build());
}
public void createButtonNotification(Context context, String title, String content, String idb, String idv) {
// Prepare intent which is triggered if the notification button is pressed
Log.d("idb", idb);
Intent intent = new Intent(getActivity(), MainPetInformation.class);
intent.putExtra("IDBIN", idb);
intent.putExtra("IDVAK", idv);
mNotificationManager = (NotificationManager)context.getSystemService(getActivity().NOTIFICATION_SERVICE);
Uri uri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
int IntID = Integer.valueOf(idb);
PendingIntent IntentAccept = PendingIntent.getActivity(getActivity(), IntID, intent, 0);
PendingIntent IntentCancel = PendingIntent.getActivity(getActivity(), IntID, intent, 0);
// Building the notifcation
NotificationCompat.Builder nBuilder = new NotificationCompat.Builder(context)
.setSmallIcon(R.drawable.logo) // notification icon
.setContentTitle(title) // notification title
.setContentText(content)
.setSound(uri)// content text
.addAction(R.drawable.accept, "Accept", IntentAccept) // accept notification button
.addAction(R.drawable.cancel, "Cancel", IntentCancel); // cancel notification button
mNotificationManager.notify(IntID, nBuilder.build());
}
}
mNotificationManager.notify(IntID, nBuilder.build());
最佳答案
由于尝试在 onCreate 方法之外设置 contentView,我遇到了这个问题。
我在 kotlin 中执行此操作,但忘记使用 by lazy
关于android - 'android.content.pm.ApplicationInfo android.content.Context.getApplicationInfo()' 在通知通知 Android 时在空对象引用上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34197026/
什么是 SASS 方法要求干燥这样的东西: .content p, .content ul, .content li, .content a 最佳答案 这 4 个元素都有共同的样式吗? .conten
我正在评估 Contentful.com 作为 Angular SPA 的内容引擎。 我面临的问题是按内容类型检索条目(例如,获取“博客”类型的所有条目)。如 documentation exampl
在我编辑的主 wiki 上有一个名为 Item: 的自定义命名空间,提示是该命名空间内的每个页面都显示为 Item:This_item - - Item:That_item -- Item:Foo_i
我正在尝试编写一个Python脚本,可以将图片和pdf上传到WordPress。我希望图像上传到文件夹‘/wp-Content/Uploads/’,将pdf文件上传到文件夹‘/wp-Content/U
是否可以监控进行了多少次 Contentful API 调用,并理想地在即将超过配额时收到通知? 谢谢 最佳答案 当然,您可以在右侧用户配置文件的下拉菜单 > Organizations and Bi
我在尝试在 IE8 中下载带有分号的文件名时遇到问题。 Response.AddHeader("Content-Disposition", "attachment; filename=\"" + at
我在 Contentful Delivery API 中运行查询以返回基于它的 slug 的特定页面项目。这个查询还设置了语言环境,以便它只返回我需要呈现的语言的数据。 但是,我还需要设置页面的 hr
我有兴趣使用 Gatsby建一个Netlify使用来自 Contentful 的内容的静态网站 Netlify 有这个不错的 Gatsby 入门指南: https://www.netlify.com/
目标是提交一个 git 分支。分支的“git status”的输出是: On branch zeromq_new Your branch is up to date with 'origin/zero
我目前正在学习在 ASP.NET 3.5 和 C# 中使用 MasterPages 和 ContentPlaceHolders - 现在,我正在拼命尝试通过我的编程代码编辑 asp:Content-C
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我使用 bootstrap 3 作为我的网格框架和 CSS 来创建一个具有一个倾斜/倾斜边缘的半透明区域,但由于分层不透明度,我的元素遇到了问题。 期望是中心是倾斜的,但右侧仍然是正方形。 有没有更好
IllegalArgumentException: 未知 URL 内容:// ^ 对上述内容做了噩梦。我检查了我的变量和路径,但看不出问题是什么?非常感谢任何指点! 这是我的痕迹。 java.lan
我有两个元素:一个是 元素,另一个是 元素。 populated-drop-down extends drop-down ,但是,正如您可能已经猜到的那样,它会尝试使用一些选项预先填充它。假设我可以简
我想我也有同样的问题。 Using multiple yields to insert content 我尝试了这个解决方案。我试过 在我的 application.html.erb 中有 conte
此链接 ( https://css-tricks.com/snippets/css/a-guide-to-flexbox/ ) 表示 justify-content 和 align-content 的
我现在正在探索绑定(bind),并且有一个 NSPopUpButton - 它为我提供了一些值选择下的绑定(bind)选项 - Content , Content Objects , Content
正在尝试在内容页面中加载内容 View 。当我运行代码时,它不会出现在我的内容 View 中。我正在从我的内容页面分配两个可绑定(bind)参数。 内容页面: 内容 View :
我想从我的 :before 标签中获取 content。我知道有些人会说它不是真正的(伪)元素,但在 JS 中有一种方法,但有人可以帮助我在 JQ 中做到这一点,因为我有多个标签并且我想用 $.eac
我创建了一个.sh脚本,并将结果记录在一个文件中,执行后我会尝试将文件内容作为mail正文发送。 这是我运行的命令: sh update.sh >> update.$(date +"%Y-%m-%d:
我是一名优秀的程序员,十分优秀!