Ответ 1
Проблема заключалась в использовании Proguard
, я не использовал @Keep
для своих классов pojo, поэтому при попытке сериализации класса с firebase
данных firebase
не находил атрибуты, потому что они были запутаны.
У меня большая проблема, я не знаю, что происходит, я загрузил приложение в Play Store, потому что когда я запускал его на эмуляторе или даже на своем реальном устройстве, он не разбивался, но теперь, когда я загружаю он из Google Play говорит:
java.lang.NullPointerException:
at com..onBindViewHolder (ChooseCard.java)
or .onCreateViewHolder (ChooseCard.java)
at com..onBindViewHolder (ChooseCard.java)
or .onCreateViewHolder (ChooseCard.java)
at com.firebase.ui.database.FirebaseRecyclerAdapter.getItemCount (FirebaseRecyclerAdapter.java)
or .onBindViewHolder (FirebaseRecyclerAdapter.java)
or .onChildChanged (FirebaseRecyclerAdapter.java)
or .onError (FirebaseRecyclerAdapter.java)
at com.yarolegovich.discretescrollview.InfiniteScrollAdapter.access$100 (InfiniteScrollAdapter.java)
or .getItemCount (InfiniteScrollAdapter.java)
or .getItemViewType (InfiniteScrollAdapter.java)
or .onAttachedToRecyclerView (InfiniteScrollAdapter.java)
or .onBindViewHolder (InfiniteScrollAdapter.java)
or .onCreateViewHolder (InfiniteScrollAdapter.java)
or .wrap (InfiniteScrollAdapter.java)
Это были дни с этой проблемой, и я не могу это узнать, не могли бы вы мне дать руку?
Там мои реализации build.gradle
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support.constraint:constraint-layout:1.1.0'
implementation 'com.android.support:design:27.1.1'
implementation 'com.intuit.sdp:sdp-android:1.0.4'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
implementation 'com.android.support:cardview-v7:27.1.1'
implementation 'com.google.firebase:firebase-core:15.0.0'
implementation 'com.google.firebase:firebase-auth:15.0.0'
implementation 'com.google.android.gms:play-services-auth:15.0.0'
implementation 'com.google.firebase:firebase-database:15.0.0'
implementation 'com.anjlab.android.iab.v3:library:1.0.44'
implementation 'com.firebaseui:firebase-ui-database:3.3.1'
implementation 'com.onesignal:OneSignal:3.7.1'
implementation 'com.yarolegovich:discrete-scrollview:1.3.2'
implementation 'com.pranavpandey.android:dynamic-toasts:0.9.0'
implementation 'pl.droidsonroids.gif:android-gif-drawable:1.2.11'
implementation 'com.google.android.gms:play-services-analytics:15.0.0'
.....
dependencies {
classpath 'com.android.tools.build:gradle:3.1.2'
classpath 'com.google.gms:google-services:3.2.1'
Я обновил свое приложение в Google Play, и ничего не происходит, все еще сбой в одной и той же Activity
, теперь я знаю, что делать, чтобы отладить это, проблема заключается в том, когда я загружаю приложение из Google Play на эмуляторе (даже в новом эмулятор не сбой) и на моем реальном устройстве.
Как сказал @Marcos Vascondelos, я сделал Build> Genereate Signed APK> получил приложение-release.apk, установив его на свое устройство, и проблема в том, что я не могу войти в систему, он идет по этому методу:
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
if (requestCode == RC_SIGN_IN) {
Task<GoogleSignInAccount> task = GoogleSignIn.getSignedInAccountFromIntent(data);
try {
// Google Sign In was successful, authenticate with Firebase
GoogleSignInAccount account = task.getResult(ApiException.class);
firebaseAuthWithGoogle(account);
} catch (ApiException e) {
// Google Sign In failed, update UI appropriately
Log.w(TAG, "Google sign in failed", e.getCause());
Toast with e.getCause is null
}
}
}
Если вы хотите посмотреть, как я могу войти, чтобы не помещать больше кода на этот вопрос, я надел этот GitHubGist
Я читал, что это могут быть проблемы с SHA-1, но я не знаю, почему на эмуляторе все в порядке, устройство в порядке, игра Google в порядке, но если я устанавливаю.apk прямо, он говорит null.
Я вижу, что проблема заключается не в вызове Firebase
, а в заполнении списка, я имею в виду, что продукты пойманы правильно, но когда я пытаюсь поместить в список, это то, где он падает
Адаптер FirebaseRecyclerOptions
выглядит так:
final FirebaseRecyclerOptions< CardPOJO > options =
new FirebaseRecyclerOptions.Builder< CardPOJO >()
.setQuery(products_ref, CardPOJO.class)
.build();
adapter = new FirebaseRecyclerAdapter< CardPOJO, CardHolder>(options) {
@Override
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
@Override
public void onDataChanged() {
super.onDataChanged();
if(progressDialog!=null)progressDialog.dismiss();initViews();
}
@Override
protected void onBindViewHolder(final CardHolder holder, int position, final CardPOJO model) {
holder.itemView.setSelected(0== position); ////where you are in the list
holder.getLayoutPosition();
switch (model.getState()){
case "free":
holder.card_image.setImageResource();
break;
case "not_free":
if(userOwnsProduct(model.getProduct_id())){
holder.card_image.setImageResource();
}
else{
holder.card_image.setImageResource();
}
break;
default:
break;
}
holder.view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(model.getState().equals("free")){
//normal stuff1
}
else{
if (!readyToPurchase) {
DynamicToast.makeError(mContext,"Problems with Google Play",Toast.LENGTH_SHORT).show();
return;
}
root_ref.child("PurchasedProducts").child(currentUser).addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if(dataSnapshot.hasChild(model.getProduct_id())){
//Normal stuff
}
else{
bp.purchase((Activity) mContext,model.getProduct_id());
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
}
});
}
};
adapter.startListening();
infiniteAdapter = InfiniteScrollAdapter.wrap(adapter);
itemPicker.setAdapter(infiniteAdapter);
//.setItemTransitionTimeMillis(DiscreteScrollViewOptions.getTransitionTime());
itemPicker.setItemTransformer(new ScaleTransformer.Builder()
.setMinScale(0.5f)
.build());
Проблема заключалась в использовании Proguard
, я не использовал @Keep
для своих классов pojo, поэтому при попытке сериализации класса с firebase
данных firebase
не находил атрибуты, потому что они были запутаны.
Помните, всегда проверяйте, является ли компонент нулевым или нет. Затем выполните свой код. пример:
if ("your_component" != null){
//your code
}
Кажется, вы пробовали почти все, что я мог придумать. Это может быть проблема с SHA-1. Попробуйте это:
Хорошо, вот оно! Я видел код, в котором аномалия, возможно, игнорируется, например, в верхнем конце apis. В простых словах для api 23 и> 23, как получение контекста с помощью ViewGroup Parent в области viewHolder! это не проблема, но на небольших устройствах api я думаю, что это будет проблемой!
поэтому попробуйте эту надежду, это поможет!
Возможно, я вижу, что с этой точки зрения надеюсь, что это поможет
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
// !!!!!!!!!!!!! **the issue is here**! !!!!!!!!!!!!!!!
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
У вас нет правильной настройки вашего макета! Получение контекста, подобного этому, возможно, является причиной NULL POINTER EXCEPTION в этом классе! Существует простой способ сделать это! например, получить контекст активности, взяв его с помощью конструктора адаптера при создании экземпляра.
вот пример!
public class yourActivity extends AppCompatActivity{
YourAdapter mAdapter;
/// lets say you are setting it up in android ONCREATE Method
@override
public void OnCreate(....){
...........
mAdapter(data,design,YourActivity.this);
//here this will be the context going in your adapter simple
}
}
В своем конструкторе адаптера вы можете хранить его в глобальной переменной, например,
public class YourAdapter extends RECYCLERView.Adapter......{
Context mContext;
public YourAdapter(Data data, int design,Context mContext)
this.mContext = mContext;
}
//and now you can access without any stress about context null exception
public CardHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//inflate the single recycler view layout(item)
View view = LayoutInflater.from(mContext)
.inflate(R.layout.card_product, parent, false);
final CardHolder cardViewHolder = new CardHolder(view);
return cardViewHolder;
}
ПЕРВАЯ АНОМАЛИЯ раскрывается и разрешается с помощью приведенного выше кода. второй, который я надеялся, подобен этому
Вы пытаетесь использовать RecyclerView, но не предоставляете его SubClass для хранения представлений!
Когда мы делаем адаптер для просмотра в ресайклере, они должны обладать подклассом для ViewHolder, чтобы сделать просто переработку для нас. основная работа этого подкласса заключается в том, чтобы удерживать Views и findThem, используя их идентификаторы
для типичного примера попробуйте эту ссылку, которую я нашел! кредит идет на git writer.