Android 无法充气浮动操作按钮错误

Android 无法充气浮动操作按钮错误,android,android-layout,inflate-exception,floating-action-button,Android,Android Layout,Inflate Exception,Floating Action Button,我无法启动我的活动,应用程序强制关闭,一个关于无法为晶圆厂充气的错误,我已经阅读了针对一些问题提供的其他答案,但其中大多数提到更改xml中的背景色属性,其他提到将compat属性添加到活动中,我已经做了,但仍然得到错误。有谁能找出我做错了什么 错误日志 无法启动活动组件信息{com.fayaz.pix/com.fayaz.pix.MainActivity}:android.view.InflateException:二进制XML文件行#24:二进制XML文件行#24:对类android.supp

我无法启动我的
活动
,应用程序强制关闭,一个关于无法为
晶圆厂
充气的错误,我已经阅读了针对一些问题提供的其他答案,但其中大多数提到更改xml中的背景色属性,其他提到将compat属性添加到活动中,我已经做了,但仍然得到错误。有谁能找出我做错了什么

错误日志

无法启动活动组件信息{com.fayaz.pix/com.fayaz.pix.MainActivity}:android.view.InflateException:二进制XML文件行#24:二进制XML文件行#24:对类android.support.design.widget.FloatingActionButton进行膨胀时出错

活动\u main.xml

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.fayaz.pix.MainActivity">

<android.support.design.widget.AppBarLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:theme="@style/AppTheme.AppBarOverlay">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="?attr/colorPrimary"
        app:popupTheme="@style/AppTheme.PopupOverlay" />

</android.support.design.widget.AppBarLayout>

<include layout="@layout/content_main" />

<android.support.design.widget.FloatingActionButton
    android:id="@+id/fab"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom|end"
    android:layout_margin="@dimen/fab_margin"
    app:srcCompat="@android:drawable/ic_dialog_email" />
</android.support.design.widget.CoordinatorLayout>
活动

public class MainActivity extends AppCompatActivity {

private RecyclerView mPostRV;
private FirebaseRecyclerAdapter<Post, PostViewHolder> mPostAdapter;
private DatabaseReference mPostRef;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    initialiseScreen();

    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            sendPosttoFirebase();
        }
    });
}

private void sendPosttoFirebase() {
    Post post = new Post();
    String UID = Utils.getUID();

    post.setUID(UID);
    post.setNumLikes(0);
    post.setImageUrl("https://static.pexels.com/photos/36487/above-adventure-aerial-air.jpg");

    mPostRef.child(UID).setValue(post);
}

private void initialiseScreen() {
    mPostRV = (RecyclerView)findViewById(R.id.post_rv);
    mPostRV.setLayoutManager(new LinearLayoutManager(MainActivity.this));
    mPostRef = FirebaseDatabase.getInstance().getReference(Constants.POSTS);
    setupAdapter();
    mPostRV.setAdapter(mPostAdapter);
}

private void setupAdapter() {
    mPostAdapter = new FirebaseRecyclerAdapter<Post, PostViewHolder>(Post.class, R.layout.item_layout,PostViewHolder.class, mPostRef) {
        @Override
        protected void populateViewHolder(PostViewHolder viewHolder, final Post model, int position) {
            StorageReference storageReference = FirebaseStorage.getInstance().getReferenceFromUrl(model.getImageUrl());
            Glide.with(MainActivity.this)
                    .using(new FirebaseImageLoader())
                    .load(storageReference)
                    .into(viewHolder.postIV);
            viewHolder.setNumLikes(model.getNumLikes());
            viewHolder.postLikes.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    updateNumLikes(model.getUID());
                }
            });
        }
    };
}

private void updateNumLikes(String uid) {
    mPostRef.child(uid).child(Constants.NUM_LIKES).runTransaction(new Transaction.Handler() {
        @Override
        public Transaction.Result doTransaction(MutableData mutableData) {
            long num = (long) mutableData.getValue();
            num++;
            mutableData.setValue(num);
            return Transaction.success(mutableData);
        }

        @Override
        public void onComplete(DatabaseError databaseError, boolean b, DataSnapshot dataSnapshot) {

        }
    });
}

public static class PostViewHolder extends RecyclerView.ViewHolder {
    public ImageView postIV, postLikes;
    public TextView numLikes;

    public PostViewHolder(View itemView) {
        super(itemView);

        postIV = (ImageView)itemView.findViewById(R.id.post_iv);
        postLikes = (ImageView)itemView.findViewById(R.id.likes_iv);
        numLikes =  (TextView)itemView.findViewById(R.id.num_likes_tv);

    }

    public void setNumLikes(long num){
        numLikes.setText(String.valueOf(num));`enter code here`
    }
}
}
public类MainActivity扩展了AppCompatActivity{
私人回收站;
私人FirebaseRecyclerAdapter MPOStatadapter;
私有数据库参考mPostRef;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar Toolbar=(Toolbar)findViewById(R.id.Toolbar);
设置支持操作栏(工具栏);
初始化屏幕();
FloatingActionButton fab=(FloatingActionButton)findViewById(R.id.fab);
fab.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图){
sendPosttoFirebase();
}
});
}
私有void sendPosttoFirebase(){
Post Post=新Post();
字符串UID=Utils.getUID();
post.setUID(UID);
post.setNumLikes(0);
post.setImageUrl(“https://static.pexels.com/photos/36487/above-adventure-aerial-air.jpg");
mPostRef.child(UID).setValue(post);
}
私有void initialiseScreen(){
mPostRV=(RecyclerView)findViewById(R.id.post_rv);
mPostRV.setLayoutManager(新的LinearLayoutManager(MainActivity.this));
mPostRef=FirebaseDatabase.getInstance().getReference(Constants.POSTS);
setupAdapter();
mPostRV.setAdapter(mpostatadapter);
}
私有void setupAdapter(){
mPostAdapter=新的FirebaseRecyclerAdapter(Post.class,R.layout.item_布局,PostViewHolder.class,mPostRef){
@凌驾
受保护的void populateViewHolder(PostViewHolder viewHolder,最终Post模型,int位置){
StorageReference-StorageReference=FirebaseStorage.getInstance().getReferenceFromUrl(model.getImageUrl());
使用(MainActivity.this)滑动
.使用(新的FireBaseMageLoader())
.load(存储参考)
.into(viewHolder.postIV);
setNumLikes(model.getNumLikes());
viewHolder.postLikes.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
updateNumLikes(model.getUID());
}
});
}
};
}
私有void更新(字符串uid){
mPostRef.child(uid).child(Constants.NUM_LIKES).runTransaction(newtransaction.Handler()){
@凌驾
公共事务.Result doTransaction(MutableData MutableData){
long num=(long)mutableData.getValue();
num++;
mutableData.setValue(num);
返回事务。成功(可变数据);
}
@凌驾
public void onComplete(DatabaseError DatabaseError、布尔b、DataSnapshot DataSnapshot){
}
});
}
公共静态类PostViewHolder扩展了RecyclerView.ViewHolder{
公共图像查看postIV、postLikes;
公共文本视图核武器;
公共PostViewHolder(查看项目视图){
超级(项目视图);
postIV=(ImageView)itemView.findViewById(R.id.post_iv);
postLikes=(ImageView)itemView.findViewById(R.id.likes_iv);
numLikes=(TextView)itemView.findViewById(R.id.num\u likes\u tv);
}
公共无效setNumLikes(长数值){
numLikes.setText(String.valueOf(num));`在这里输入代码`
}
}
}
显示

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.fayaz.pix">
<uses-permission android:name="android.permission.INTERNET"/>
<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity
        android:name=".MainActivity"
        android:label="@string/app_name"
        android:theme="@style/AppTheme.NoActionBar">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

</manifest>


我不知道它是否有效,但您是否尝试使用线性布局或相对布局来包围您的所有xml代码?

您是否在gradle中导入了材料库?发布您的活动和gradlewhy srcCompat?ic\u对话框\u电子邮件是矢量绘图的吗?我用src试过,只是用srcCompat试过,但还是不起作用。@rahul,有什么想法吗?
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.fayaz.pix">
<uses-permission android:name="android.permission.INTERNET"/>
<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity
        android:name=".MainActivity"
        android:label="@string/app_name"
        android:theme="@style/AppTheme.NoActionBar">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

</manifest>