Firebase ui recyclerview - 在使用 Firebase 之前需要使用 Firebase.setAndroidContext() 设置 Android 上下文
Firebase ui recyclerview - need to set the Android context using Firebase.setAndroidContext() before using Firebase
我想要 firebase 数据库中的所有项目,所以我使用 recyclerview 来填充这些项目。当调用带有 recylerview 的 activity 时,应用程序崩溃并出现致命错误。
这是我的代码
我的java文件
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.widget.ListView;
import android.widget.TextView;
import com.firebase.client.Firebase;
import com.firebase.geofire.GeoFire;
import com.firebase.ui.FirebaseListAdapter;
import com.firebase.ui.FirebaseRecyclerAdapter;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
public class RequestPendingActivity extends AppCompatActivity {
RecyclerView RequestListView;
Firebase ref = new Firebase("https://simplyparc.firebaseio.com/Valet Requests Location");
private DatabaseReference mDatabase;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_request_pending);
RequestListView = (RecyclerView) findViewById(R.id.RequestListView);
RequestListView.setHasFixedSize(true);
RequestListView.setLayoutManager(new LinearLayoutManager(this));
GeoFire geoFire = new GeoFire(mDatabase);
}
@Override
protected void onStart(){
super.onStart();
FirebaseRecyclerAdapter<String, MessageViewHolder> adapter = new FirebaseRecyclerAdapter<String, MessageViewHolder>(String.class, android.R.layout.two_line_list_item, MessageViewHolder.class, ref) {
@Override
protected void populateViewHolder(MessageViewHolder messageViewHolder, String s, int i) {
messageViewHolder.mText.setText(s);
}
};
RequestListView.setAdapter(adapter);
}
public static class MessageViewHolder extends RecyclerView.ViewHolder{
TextView mText;
public MessageViewHolder(View v){
super(v);
mText = (TextView) v.findViewById(android.R.id.text1);
}
}
}
我的 android 清单文件
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity
android:name=".FirstActivity"
android:theme="@style/AppTheme.NoActionBar"
android:screenOrientation="portrait">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".PendingSelectorActivity"
android:label="Select Pending task"
android:screenOrientation="portrait"/>
<activity
android:name=".RequestPendingActivity"
android:label="Pending Request"
android:screenOrientation="portrait"/>
<!--
The API key for Google Maps-based APIs is defined as a string resource.
(See the file "res/values/google_maps_api.xml").
Note that the API key is linked to the encryption key used to sign the APK.
You need a different API key for each encryption key, including the release key that is used to
sign the APK for publishing.
You can define the keys for the debug and release targets in src/debug/ and src/release/.
-->
<meta-data
android:name="com.google.android.geo.API_KEY"
android:value="@string/google_maps_key"/>
<activity
android:name=".RequestAcceptMapActivity"
android:label="@string/title_activity_request_accept_map"
android:screenOrientation="portrait"/>
<activity
android:name=".DropOffActivity"
android:label="Drop-Off Request"
android:screenOrientation="portrait"/>
</application>
运行时出现致命错误
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.zuke.zukevalet, PID: 9243
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.zuke.zukevalet/com.example.zuke.zukevalet.RequestPendingActivity}: java.lang.RuntimeException: You need to set the Android context using Firebase.setAndroidContext() before using Firebase.
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2548)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
Caused by: java.lang.RuntimeException: You need to set the Android context using Firebase.setAndroidContext() before using Firebase.
at com.firebase.client.core.Context.getPlatform(Context.java:45)
at com.firebase.client.core.Context.ensureLogger(Context.java:218)
at com.firebase.client.core.Context.initServices(Context.java:105)
at com.firebase.client.core.Context.freeze(Context.java:92)
at com.firebase.client.core.RepoManager.getLocalRepo(RepoManager.java:55)
at com.firebase.client.core.RepoManager.getRepo(RepoManager.java:19)
at com.firebase.client.Firebase.<init>(Firebase.java:172)
at com.firebase.client.Firebase.<init>(Firebase.java:177)
at com.firebase.client.Firebase.<init>(Firebase.java:155)
at com.example.zuke.zukevalet.RequestPendingActivity.<init>(RequestPendingActivity.java:21)
at java.lang.Class.newInstance(Native Method)
at android.app.Instrumentation.newActivity(Instrumentation.java:1078)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2538)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
W/DynamiteModule: Local module descriptor class for com.google.firebase.auth not found.
我哪里错了?
在异常消息中:
You need to set the Android context using Firebase.setAndroidContext() before using Firebase
:
To quote (step 4 of) the Firebase quickstart documentation:
The Firebase library must be initialized once with an Android Context
. This must happen before any Firebase reference is created
or used.
创建MyApplication.java
:
public class MyApplication extends android.app.Application {
@Override
public void onCreate() {
super.onCreate();
Firebase.setAndroidContext(this);
}
}
并在 AndroidManifest.xml
:
中更新 name 参数值
<application
android:label="@string/app_name"
android:name=".MyApplication">
...
</application>
我想要 firebase 数据库中的所有项目,所以我使用 recyclerview 来填充这些项目。当调用带有 recylerview 的 activity 时,应用程序崩溃并出现致命错误。
这是我的代码
我的java文件
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.widget.ListView;
import android.widget.TextView;
import com.firebase.client.Firebase;
import com.firebase.geofire.GeoFire;
import com.firebase.ui.FirebaseListAdapter;
import com.firebase.ui.FirebaseRecyclerAdapter;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
public class RequestPendingActivity extends AppCompatActivity {
RecyclerView RequestListView;
Firebase ref = new Firebase("https://simplyparc.firebaseio.com/Valet Requests Location");
private DatabaseReference mDatabase;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_request_pending);
RequestListView = (RecyclerView) findViewById(R.id.RequestListView);
RequestListView.setHasFixedSize(true);
RequestListView.setLayoutManager(new LinearLayoutManager(this));
GeoFire geoFire = new GeoFire(mDatabase);
}
@Override
protected void onStart(){
super.onStart();
FirebaseRecyclerAdapter<String, MessageViewHolder> adapter = new FirebaseRecyclerAdapter<String, MessageViewHolder>(String.class, android.R.layout.two_line_list_item, MessageViewHolder.class, ref) {
@Override
protected void populateViewHolder(MessageViewHolder messageViewHolder, String s, int i) {
messageViewHolder.mText.setText(s);
}
};
RequestListView.setAdapter(adapter);
}
public static class MessageViewHolder extends RecyclerView.ViewHolder{
TextView mText;
public MessageViewHolder(View v){
super(v);
mText = (TextView) v.findViewById(android.R.id.text1);
}
}
}
我的 android 清单文件
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity
android:name=".FirstActivity"
android:theme="@style/AppTheme.NoActionBar"
android:screenOrientation="portrait">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".PendingSelectorActivity"
android:label="Select Pending task"
android:screenOrientation="portrait"/>
<activity
android:name=".RequestPendingActivity"
android:label="Pending Request"
android:screenOrientation="portrait"/>
<!--
The API key for Google Maps-based APIs is defined as a string resource.
(See the file "res/values/google_maps_api.xml").
Note that the API key is linked to the encryption key used to sign the APK.
You need a different API key for each encryption key, including the release key that is used to
sign the APK for publishing.
You can define the keys for the debug and release targets in src/debug/ and src/release/.
-->
<meta-data
android:name="com.google.android.geo.API_KEY"
android:value="@string/google_maps_key"/>
<activity
android:name=".RequestAcceptMapActivity"
android:label="@string/title_activity_request_accept_map"
android:screenOrientation="portrait"/>
<activity
android:name=".DropOffActivity"
android:label="Drop-Off Request"
android:screenOrientation="portrait"/>
</application>
运行时出现致命错误
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.zuke.zukevalet, PID: 9243
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.zuke.zukevalet/com.example.zuke.zukevalet.RequestPendingActivity}: java.lang.RuntimeException: You need to set the Android context using Firebase.setAndroidContext() before using Firebase.
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2548)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
Caused by: java.lang.RuntimeException: You need to set the Android context using Firebase.setAndroidContext() before using Firebase.
at com.firebase.client.core.Context.getPlatform(Context.java:45)
at com.firebase.client.core.Context.ensureLogger(Context.java:218)
at com.firebase.client.core.Context.initServices(Context.java:105)
at com.firebase.client.core.Context.freeze(Context.java:92)
at com.firebase.client.core.RepoManager.getLocalRepo(RepoManager.java:55)
at com.firebase.client.core.RepoManager.getRepo(RepoManager.java:19)
at com.firebase.client.Firebase.<init>(Firebase.java:172)
at com.firebase.client.Firebase.<init>(Firebase.java:177)
at com.firebase.client.Firebase.<init>(Firebase.java:155)
at com.example.zuke.zukevalet.RequestPendingActivity.<init>(RequestPendingActivity.java:21)
at java.lang.Class.newInstance(Native Method)
at android.app.Instrumentation.newActivity(Instrumentation.java:1078)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2538)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
W/DynamiteModule: Local module descriptor class for com.google.firebase.auth not found.
我哪里错了?
在异常消息中:
You need to set the Android context using Firebase.setAndroidContext() before using Firebase
To quote (step 4 of) the Firebase quickstart documentation:
The Firebase library must be initialized once with an Android
Context
. This must happen before any Firebase reference is created or used.创建
MyApplication.java
:public class MyApplication extends android.app.Application { @Override public void onCreate() { super.onCreate(); Firebase.setAndroidContext(this); } }
并在
中更新 name 参数值AndroidManifest.xml
:<application android:label="@string/app_name" android:name=".MyApplication"> ... </application>