我正在使用shamanland fonticonview,但我的活动无法启动,我的应用程序崩溃
牛排跟踪:

     FATAL EXCEPTION: main
   Process: com.example.mmido.asfarandroid, PID: 14010
   java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.mmido.asfarandroid/com.example.mmido.asfarandroid.As
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2385)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2436)
       at android.app.ActivityThread.access$800(ActivityThread.java:157)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1374)
       at android.os.Handler.dispatchMessage(Handler.java:110)
       at android.os.Looper.loop(Looper.java:193)
       at android.app.ActivityThread.main(ActivityThread.java:5398)
       at java.lang.reflect.Method.invokeNative(Native Method)
       at java.lang.reflect.Method.invoke(Method.java:515)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:940)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756)
       at dalvik.system.NativeStart.main(Native Method)
    Caused by: android.view.InflateException: Binary XML file line #15: Error inflating class com.shamanland.fonticon.FontIconView
       at android.view.LayoutInflater.createView(LayoutInflater.java:620)
       at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696)
       at android.view.LayoutInflater.rInflate(LayoutInflater.java:755)
       at android.view.LayoutInflater.rInflate(LayoutInflater.java:758)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
       at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:280)
       at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140)
       at com.example.mmido.asfarandroid.AsfarApp.PaymentActivity.onCreate(PaymentActivity.java:13)
       at android.app.Activity.performCreate(Activity.java:5264)
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1088)
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2349)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2436) 
       at android.app.ActivityThread.access$800(ActivityThread.java:157) 
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1374) 
       at android.os.Handler.dispatchMessage(Handler.java:110) 
       at android.os.Looper.loop(Looper.java:193) 
       at android.app.ActivityThread.main(ActivityThread.java:5398) 
       at java.lang.reflect.Method.invokeNative(Native Method) 
       at java.lang.reflect.Method.invoke(Method.java:515) 
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:940) 
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756) 
       at dalvik.system.NativeStart.main(Native Method) 
    Caused by: java.lang.reflect.InvocationTargetException
       at java.lang.reflect.Constructor.constructNative(Native Method)
       at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
       at android.view.LayoutInflater.createView(LayoutInflater.java:594)
       at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696) 
       at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) 
       at android.view.LayoutInflater.rInflate(LayoutInflater.java:758) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:492) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:353) 
       at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:280) 
       at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140) 
       at com.example.mmido.asfarandroid.AsfarApp.PaymentActivity.onCreate(PaymentActivity.java:13) 
       at android.app.Activity.performCreate(Activity.java:5264) 
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1088) 
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2349) 
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2436) 
       at android.app.ActivityThread.access$800(ActivityThread.java:157) 
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1374) 
       at android.os.Handler.dispatchMessage(Handler.java:110) 
       at android.os.Looper.loop(Looper.java:193) 
       at android.app.ActivityThread.main(ActivityThread.java:5398) 
       at java.lang.reflect.Method.invokeNative(Native Method) 
       at java.lang.reflect.Method.invoke(Method.java:515) 
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:940) 
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756) 
       at dalvik.system.NativeStart.main(Native Method) 
    Caused by: java.lang.IllegalStateException
       at com.shamanland.fonticon.FontIconTypefaceHolder.getTypeface(FontIconTypefaceHolder.java:11)
       at com.shamanland.fonticon.FontIconView.<init>(FontIconView.java:129)
       at java.lang.reflect.Constructor.constructNative(Native Method) 
       at java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
       at android.view.LayoutInflater.createView(LayoutInflater.java:594) 
       at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:696) 
       at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) 
       at android.view.LayoutInflater.rInflate(LayoutInflater.java:758) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:492) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:353) 
       at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:280) 
       at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140) 
       at com.example.mmido.asfarandroid.AsfarApp.PaymentActivity.onCreate(PaymentActivity.java:13) 
       at android.app.Activity.performCreate(Activity.java:5264) 
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1088) 
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2349) 
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2436) 
       at android.app.ActivityThread.access$800(ActivityThread.java:157) 
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1374) 
       at android.os.Handler.dispatchMessage(Handler.java:110) 
       at android.os.Looper.loop(Looper.java:193) 
       at android.app.ActivityThread.main(ActivityThread.java:5398) 
       at java.lang.reflect.Method.invokeNative(Native Method) 
       at java.lang.reflect.Method.invoke(Method.java:515) 
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:940) 
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756) 
       at dalvik.system.NativeStart.main(Native Method) 

我的布局:
?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    android:focusableInTouchMode="true"
    android:orientation="vertical">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="@dimen/pf_tittle_header_height"
        android:background="@color/pf_gray">

        <com.shamanland.fonticon.FontIconView
            android:id="@+id/backButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_margin="@dimen/pf_border_space"
            android:clickable="true"
            android:onClick="onBackPressed"
            android:text="@string/icon_left_circled"
            android:textColor="@android:color/white"
            android:textSize="@dimen/pf_back_icon_txt_size"
            app:pressedGlowColor="@color/pf_green"
            app:pressedGlowRadius="@dimen/pf_icon_glow_radius" />

15号线是这条线<com.shamanland.fonticon.FontIconView
我检查了fonticonview中使用的字符串值和维度,它们是正确的。请问这里有什么错误?
谢谢。

最佳答案

前天我在我的项目中也遇到了同样的问题,所以我找到的解决方案是:将.ttf文件粘贴到项目中的asset文件夹中(如果文件夹不存在,只需在app->src->main中创建一个),并初始化主activity insideFontIconTypefaceHolder()方法中的onCreate()。就像

FontIconTypefaceHolder.init(getAssets(),"icon.ttf");

10-07 15:47