получение исключения инфляции макета после обновления целевого SDK до 29 - PullRequest
0 голосов
/ 04 августа 2020

После обновления Target SDK Version до 29 я получаю эту ошибку в My BaseFragment

Доступ к скрытому полю Landroid / view / LayoutInflater; -> mConstructorArgs: [Ljava / lang / Object; (greylist-max-p, reflection, denied)

двоичный XML строка файла # 38 в common_base_fragment: двоичный XML строка файла # 2 в worker_list_empty_view: ошибка надувания класса androidx.swiperefreshlayout.widget .SwipeRefreshLayout Вызвано: android .view.InflateException: двоичная XML строка файла # 2 в worker_list_empty_view: ошибка надувания класса androidx.swiperefreshlayout.widget.SwipeRefreshLayout Вызвано: java .lang.NullPointerception виртуального метода. 'java .lang.Object java .lang.reflect.Field.get (java .lang.Object)' в ссылке на нулевой объект

BaseFragment

@ Nullable

@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.common_base_fragment, container, false);
    initViews(view);
    return view;
}

Фрагмент AccountBase

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    super.onCreateView(inflater, container, savedInstanceState);
    View view = inflater.inflate(R.layout.account_base_fragment, container,
            false);
    initViews(view);
    return view;
}   

Ограничения без SDK

Landroid/view/LayoutInflater;->mConstructorArgs:[Ljava/lang/Object; # No public alternative. Developers should never access this field directly.
    Landroid/view/LayoutInflater;->mContext:Landroid/content/Context; # Use getContext() to read, cloneInContext to produce a new inflater with a different context
    Landroid/view/LayoutInflater;->mFactorySet:Z # No public alternative. Developers should never access this field directly.
    Landroid/view/LayoutInflater;->sConstructorMap:Ljava/util/HashMap; # No public alternative. Developers should never access this field directly.  

Полная трассировка стека

 Process: android.view.InflateException: Binary XML file line #38 in common_base_fragment: Binary XML file line #2 in worker_list_empty_view: Error inflating class androidx.swiperefreshlayout.widget.SwipeRefreshLayout
    Caused by: android.view.InflateException: Binary XML file line #2 in worker_list_empty_view: Error inflating class androidx.swiperefreshlayout.widget.SwipeRefreshLayout
    Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Object java.lang.reflect.Field.get(java.lang.Object)' on a null object reference
        at uk.co.chrisjenx.calligraphy.ReflectionUtils.getValue(ReflectionUtils.java:29)
        at uk.co.chrisjenx.calligraphy.CalligraphyLayoutInflater.createCustomViewInternal(CalligraphyLayoutInflater.java:203)
        at uk.co.chrisjenx.calligraphy.CalligraphyLayoutInflater.access$000(CalligraphyLayoutInflater.java:20)
        at uk.co.chrisjenx.calligraphy.CalligraphyLayoutInflater$PrivateWrapperFactory2.onCreateView(CalligraphyLayoutInflater.java:302)
        at android.view.LayoutInflater$FactoryMerger.onCreateView(LayoutInflater.java:239)
        at android.view.LayoutInflater.tryCreateView(LayoutInflater.java:1069)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:997)
        at android.view.LayoutInflater.parseInclude(LayoutInflater.java:1233)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:1119)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:1126)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:682)
        at uk.co.chrisjenx.calligraphy.CalligraphyLayoutInflater.inflate(CalligraphyLayoutInflater.java:60)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:534)
        at com..ui.BaseFragment.onCreateView(BaseFragment.java:74)
        at com.ui.AccountBaseFragment.onCreateView(AccountBaseFragment.java:60)
        at com.ui.LoginFragment.onCreateView(LoginFragment.java:94)
        at androidx.fragment.app.Fragment.performCreateView(Fragment.java:2439)
        at androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManager.java:1460)
        at androidx.fragment.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1784)
        at androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManager.java:1852)
        at androidx.fragment.app.BackStackRecord.executeOps(BackStackRecord.java:802)
        at androidx.fragment.app.FragmentManagerImpl.executeOps(FragmentManager.java:2625)
        at androidx.fragment.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2411)
        at androidx.fragment.app.FragmentManagerImpl.removeRedundantOperationsAndExecute(FragmentManager.java:2366)
        at androidx.fragment.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2273)
        at androidx.fragment.app.FragmentManagerImpl.dispatchStateChange(FragmentManager.java:3273)
        at androidx.fragment.app.FragmentManagerImpl.dispatchActivityCreated(FragmentManager.java:3229)
        at androidx.fragment.app.FragmentController.dispatchActivityCreated(FragmentController.java:201)
        at androidx.fragment.app.FragmentActivity.onStart(FragmentActivity.java:620)
        at com.ui.BaseActivity.onStart(BaseActivity.java:321)
        at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1425)
        at android.app.Activity.performStart(Activity.java:7825)
        at android.app.ActivityThread.handleStartActivity(ActivityThread.java:3294)
        at android.app.servertransaction.TransactionExecutor.performLifecycleSequence(TransactionExecutor.java:221)
        at android.app.servertransaction.TransactionExecutor.cycleToPath(TransactionExecutor.java:201)
        at android.app.servertransaction.TransactionExecutor.executeLifecycleState(TransactionExecutor.java:173)
2020-08-04 14:11:19.100 3666-3666/com.prounlimited.wanddev E/AndroidRuntime:     at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:97)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016)
        at android.os.Handler.dispatchMessage(Handler.java:107)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:7356)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)

XML Файл

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <FrameLayout
        android:id="@+id/content_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <LinearLayout
        android:id="@+id/progress_view_frame"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@android:color/white"
        android:gravity="center"
        android:orientation="vertical"
        android:visibility="gone">

        <ProgressBar
            style="?android:attr/progressBarStyleLarge"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </LinearLayout>


    <FrameLayout
        android:id="@+id/empty_view_frame"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/empty_view_bg"
        android:visibility="gone">

        <include
            android:id="@+id/worker_empty_view"
            layout="@layout/worker_list_empty_view"
            android:visibility="gone" />

        <include
            android:id="@+id/mgr_empty_view"
            layout="@layout/mgr_list_empty_view"
            android:visibility="gone" />
    </FrameLayout>

    <include
        android:id="@+id/banner_view"
        layout="@layout/common_banner_view"
        android:visibility="gone" />
</FrameLayout>

worker_list_empty_view

<androidx.swiperefreshlayout.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/pale_grey"
    tools:ignore="MissingPrefix" >

    <ScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fillViewport="true" >

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center">

            <TextView
                android:id="@+id/empty_text_view"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                fontPath="@string/roboto_bold"
                android:layout_centerInParent="true"
                android:gravity="center_horizontal"
                android:paddingLeft="16dp"
                android:paddingRight="16dp"
                android:textColor="@color/empty_text_color"
                android:textSize="15sp" />

            <ImageView
                android:id="@+id/empty_img_view"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:layout_above="@id/empty_text_view"
                android:paddingBottom="27dp"  />

        </RelativeLayout>

    </ScrollView>

</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...