質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Q&A

解決済

1回答

831閲覧

NullPointerExceptionエラーが表示されるが、エラー行が表示されない

Yakusugi

総合スコア123

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

0グッド

1クリップ

投稿2022/08/03 05:03

Androidの家計簿アプリをJavaで作成しています。

ここでやりたい事は購入履歴DBにたいしてユーザが購入した商品の店名と2つの日付(最初の日付、最後の日付)を入れることで、
例えば2022/7/1~2022/7/31までにAmazonで購入した商品の商品種類を円グラフ形式で表示する仕様にしたいです。

上記コードは既に実装済みなのですが、実際に動かしてみると、どこでエラーが起きているのか行数の記載がなく、ただ「java.lang.NullPointerException: No binary data in push message」とだけ表示されます。

下記StackOverflowなどで確認すると、
.gradleフォルダーを手動で消し、その状態で再度アプリを起動/再ビルドをかけると正常に直るといった記載があったので、
下記フォルダーを削除・再ビルドしたのちに再度アプリを起動して、上記で実装した機能を動かしてみたところ、同じエラーが表示されてしまいます。
C:\Users\user_name\AndroidStudioProjects\OfflineBudgetTrackerAppProject/.gradle

https://stackoverflow.com/questions/39183674/java-lang-nullpointerexception-no-error-message

解決の為、ヒントなどがあればご回答お願い致します。

エラー文

2022-08-03 13:42:34.337 5014-5123/? E/A: Processing of GCM event failed. java.lang.NullPointerException: No binary data in push message at com.google.common.base.bb.a(PG:1) at com.google.android.apps.gsa.staticplugins.ay.k.a(PG:6) at dagger.b.a.h.apply(PG:2) at com.google.common.util.concurrent.h.e(PG:2) at com.google.common.util.concurrent.j.run(PG:9) at com.google.cc.h.a.q.run(PG:3) at com.google.android.libraries.i.af.run(PG:1) at com.google.android.libraries.i.an.run(PG:23) at com.google.android.libraries.i.l.run(PG:2) at com.google.android.libraries.i.q.run(PG:4) at java.lang.Thread.run(Thread.java:919)

StatsFragment.java

package com.myproject.offlinebudgettrackerappproject; import箇所は割愛 /** * A simple {@link Fragment} subclass. * Use the {@link StatsFragment#newInstance} factory method to * create an instance of this fragment. */ public class StatsFragment extends Fragment { private BudgetTrackerSpendingAliasViewModel budgetTrackerSpendingAliasViewModel; RadioGroup radioGroup; RadioButton radioStoreButton; EditText searchName; EditText dateFrom; EditText dateTo; Button searchBtn; ActivityMainBinding activityMainBinding; List<BudgetTrackerSpendingAlias> spendingAliasList; PieChart pieChart; ArrayList<PieEntry> pieEntries; // TextView currentCurrencyTv; // TODO: Rename parameter arguments, choose names that match // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER private static final String ARG_PARAM1 = "param1"; private static final String ARG_PARAM2 = "param2"; // TODO: Rename and change types of parameters private String mParam1; private String mParam2; public StatsFragment() { // Required empty public constructor } /** * Use this factory method to create a new instance of * this fragment using the provided parameters. * * @param param1 Parameter 1. * @param param2 Parameter 2. * @return A new instance of fragment StatsFragment. */ // TODO: Rename and change types and number of parameters public static StatsFragment newInstance(String param1, String param2) { StatsFragment fragment = new StatsFragment(); Bundle args = new Bundle(); args.putString(ARG_PARAM1, param1); args.putString(ARG_PARAM2, param2); fragment.setArguments(args); return fragment; } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); if (getArguments() != null) { mParam1 = getArguments().getString(ARG_PARAM1); mParam2 = getArguments().getString(ARG_PARAM2); } } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_stats, container, false); radioGroup = (RadioGroup) view.findViewById(R.id.stats_radio_group); radioStoreButton = (RadioButton) view.findViewById(R.id.stats_radio_store_name); searchName = (EditText) view.findViewById(R.id.stats_search_name); dateFrom = (EditText) view.findViewById(R.id.stats_search_date_from_txt); dateTo = (EditText) view.findViewById(R.id.stats_search_date_to_txt); searchBtn = (Button) view.findViewById(R.id.stats_search_btn); activityMainBinding = ActivityMainBinding.inflate(getLayoutInflater()); pieChart = (PieChart) view.findViewById(R.id.stats_pie_chart); budgetTrackerSpendingAliasViewModel = new ViewModelProvider(requireActivity()).get(BudgetTrackerSpendingAliasViewModel.class); pieEntries = new ArrayList<>(); Calendar calendar = Calendar.getInstance(); final int year = calendar.get(Calendar.YEAR); final int month = calendar.get(Calendar.MONTH); final int day = calendar.get(Calendar.DAY_OF_MONTH); dateFrom.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { DatePickerDialog datePickerDialog = new DatePickerDialog( getActivity(), new DatePickerDialog.OnDateSetListener() { @Override public void onDateSet(DatePicker datePicker, int year, int month, int dayOfMonth) { month = month + 1; String date = year + "-" + month + "-" + dayOfMonth; dateFrom.setText(date); } }, year, month, day); datePickerDialog.show(); } }); dateTo.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { DatePickerDialog datePickerDialog = new DatePickerDialog( getActivity(), new DatePickerDialog.OnDateSetListener() { @Override public void onDateSet(DatePicker datePicker, int year, int month, int dayOfMonth) { month = month + 1; String date = year + "-" + month + "-" + dayOfMonth; dateTo.setText(date); } }, year, month, day); datePickerDialog.show(); } }); searchBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { String searchKey = searchName.getText().toString(); String searchDateFrom = dateFrom.getText().toString(); String searchDateTo = dateTo.getText().toString(); if (radioGroup.getCheckedRadioButtonId() == R.id.stats_radio_store_name) { deleteAliasSpendingTable(); deleteSequence(); insertStoreDataSpendingAlias(searchDateFrom, searchDateTo, searchKey); storePieChartShow(); } else { // spdBool = true; // vatRate = Double.parseDouble(enterVatRate.getText().toString()); // price = price * vatRate; } // String notes = enterNotes.getText().toString(); // BudgetTrackerSpending budgetTrackerSpending = new BudgetTrackerSpending(date, storeName, productName, productType, price, spdBool, vatRate, notes); // budgetTrackerSpendingViewModel.insert(budgetTrackerSpending); getActivity().finish(); } }); return view; } private void deleteAliasSpendingTable() { BudgetTrackerSpendingAliasViewModel.deleteAllSpendingAlias(); } private void deleteSequence() { BudgetTrackerSpendingAliasViewModel.deleteSequence(); } private void insertStoreDataSpendingAlias(String dateFrom, String dateTo, String storeName) { BudgetTrackerSpendingAliasViewModel.insertStoreName(dateFrom, dateTo, storeName); } private void storePieChartShow() { spendingAliasList = budgetTrackerSpendingAliasViewModel.getAllBudgetTrackerSpendingAliasList(); pieEntries = new ArrayList<PieEntry>(); for (BudgetTrackerSpendingAlias budgetTrackerSpendingAlias : spendingAliasList) { float value = (float) (budgetTrackerSpendingAlias.getAliasPercentage()); String productType = budgetTrackerSpendingAlias.getProductTypeAlias(); PieEntry pieEntry = new PieEntry(value, productType); pieEntries.add(pieEntry); } PieDataSet pieDataSet = new PieDataSet(pieEntries, "Product Type Percentage"); pieDataSet.setColors(ColorTemplate.COLORFUL_COLORS); pieDataSet.setValueTextSize(20f); pieChart.notifyDataSetChanged(); pieChart.invalidate(); pieChart.setData(new PieData(pieDataSet)); pieChart.animateXY(5000, 5000); pieChart.setEntryLabelColor(Color.BLACK); pieChart.getDescription().setEnabled(false); } }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2022/08/03 05:09

エラーメッセージに「Processing of GCM event failed.」と書かれていますが、このあたりの挙動は調べてみましたか?
Yakusugi

2022/08/03 06:51

ご回答ありがとうございます。 「Processing of GCM event failed.」に関して調べてみましたが、有益な情報は得られていません。 私が調べたところでは、Firabase関連で当該エラーが多発しているようです。 今回、私が使用しているDBはAndroid Room(SQLite)で、こちらに関する情報はほとんど見当たりませんでした。
xebme

2022/08/03 07:59

java.lang.NullPointerException: No binary data in push message これがNullPointerException (no error message)と同じだとは思えません。 「プッシュメッセージにバイナリデータが含まれていない」と言っているのではないでしょうか。 それは「GCMベントの処理中に起きている」ということですね。 えーと、まずGCMイベント処理を調べるのではないでしょうか?たとえば、https://groups.google.com/g/android-gcm/c/wtHaMktu1qA 掲載したコードはすべて自作コードですか?
Yakusugi

2022/08/03 08:09

はい、StatsFragment.javaに掲載したコードは全て自作コートです。
Yakusugi

2022/08/03 08:23

私の方でも調べたのですが、GCMはGoogle Cloud Messagingの事なんですよね? 今回のプロジェクトで使用しているDBはAndroid Roomと呼ばれるローカルにデータをセーブするDBなので、外部のFirebaseの様なGoogle Cloudを使うサービスは一切使用していないはずなのですが。。。 それとも、今回円グラフを使う際に使用したMPAndroidChartがGCMと何か関連があるのでは?とも推測しています。 https://github.com/PhilJay/MPAndroidChart
guest

回答1

0

自己解決

getActivity().finish();を消すことで解決しました。

投稿2022/09/07 03:55

Yakusugi

総合スコア123

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問