Android问题加载小部件-logcat中没有错误

Posted

技术标签:

【中文标题】Android问题加载小部件-logcat中没有错误【英文标题】:Android Problem loading widget - without errors in the logcat 【发布时间】:2021-03-02 00:37:32 【问题描述】:

我在 java 中创建了一个模拟时钟小部件,由于某种原因,我一直收到“问题加载小部件”,当我尝试放置小部件时,我从 logcat 得到的唯一信息是:

2020-11-18 19:19:13.162 9482-9482/? E/Zygote: isWhitelistProcess - Process is Whitelisted
2020-11-18 19:19:13.162 9482-9482/? E/Zygote: accessInfo : 1
2020-11-18 19:19:13.166 9482-9482/? I/ckcustomizatio: Late-enabling -Xcheck:jni
2020-11-18 19:19:13.182 9482-9482/? E/ckcustomizatio: Unknown bits set in runtime_flags: 0x8000
2020-11-18 19:19:13.196 9482-9482/com.l_es.analogclockcustomization D/ActivityThread: setConscryptValidator
2020-11-18 19:19:13.196 9482-9482/com.l_es.analogclockcustomization D/ActivityThread: setConscryptValidator - put

并且该小部件只是一个黑色方块,上面有“问题加载小部件”。

这是小部件类:

public class MainWidget extends AppWidgetProvider 

    static RemoteViews views;
    //preferences
    private static SharedPreferences custClockPrefs;
    //number of possible designs
    private static int numClocks;
    //IDs of Analog Clock elements
    static int[] clockDesigns;

    public void onReceive(Context context, Intent intent) 

        numClocks = context.getResources().getInteger(R.integer.num_clocks);
        clockDesigns = new int[numClocks];
        for(int d = 0; d < numClocks; d++)
            clockDesigns[d] = context.getResources().getIdentifier
                    ("AnalogClock"+d, "id", context.getPackageName());
        
        //find out the action
        String action = intent.getAction();
        //is it time to update
        if(AppWidgetManager.ACTION_APPWIDGET_UPDATE.equals(action)) 
            views = new RemoteViews(context.getPackageName(),
                    R.layout.clock_widget_layout);

            AppWidgetManager.getInstance(context).updateAppWidget
                    (intent.getIntArrayExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS), views);

            custClockPrefs = context.getSharedPreferences("CustomClockPrefs", 0);
            int chosenDesign = custClockPrefs.getInt("clockdesign", 0);
            if(chosenDesign >= 0)
                for(int d = 0; d < numClocks; d++)
                    if(d != chosenDesign)
                        views.setViewVisibility(clockDesigns[d], View.INVISIBLE);
                
                views.setViewVisibility(clockDesigns[chosenDesign], View.VISIBLE);
            

            Intent choiceIntent = new Intent(context, ClockChoice.class);
            PendingIntent clickPendIntent = PendingIntent.getActivity
                    (context, 0, choiceIntent, PendingIntent.FLAG_UPDATE_CURRENT);
            views.setOnClickPendingIntent(R.id.custom_clock_widget, clickPendIntent);

        
    


这是我用来绘制时钟的绘图函数:

@Override
protected void onDraw(Canvas canvas) 
    super.onDraw(canvas);

    final float w = (float) getWidth() / 2;
    final float h = (float) getHeight() / 2;

    final int saveCount = canvas.save();
    canvas.translate(w, h);
    final float scale = Math.min((float) w / mDial.getIntrinsicWidth(),
            (float) h / mDial.getIntrinsicHeight());
    if (scale < 1f) 
        canvas.scale(scale, scale, 0f, 0f);
    
    mDial.draw(canvas);

    final float hourAngle = mTime.get(Calendar.HOUR) * 30f;
    canvas.rotate(hourAngle, 0f, 0f);
    mHourHand.draw(canvas);

    final float minuteAngle = mTime.get(Calendar.MINUTE) * 6f;
    canvas.rotate(minuteAngle - hourAngle, 0f, 0f);
    mMinuteHand.draw(canvas);

    if (mEnableSeconds) 
        final float secondAngle = mTime.get(Calendar.SECOND) * 6f;
        canvas.rotate(secondAngle - minuteAngle, 0f, 0f);
        mSecondHand.draw(canvas);
    
    canvas.restoreToCount(saveCount);

这是我的小部件布局文件,请记住,我每次都将 3 个中的 2 个设置为“消失”的可见性:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/custom_clock_widget"
    android:layout_
    android:layout_
    android:padding="@dimen/clock_margin"
    android:gravity="center">

    <com.l_es.analogclockcustomization.AnalogClockDesign
        android:id="@+id/AnalogClock0"
        android:layout_
        android:layout_
        app:showSecondHand="false"
        app:dial="@drawable/clock_dial_2"
        app:hour="@drawable/clock_hour_hand_2"
        app:minute="@drawable/clock_minute_hand_2"/>

    <com.l_es.analogclockcustomization.AnalogClockDesign
        android:id="@+id/AnalogClock1"
        android:layout_
        android:layout_
        app:showSecondHand="false"
        app:dial="@drawable/clock_dial_3"
        app:hour="@drawable/clock_hour_hand_3"
        app:minute="@drawable/clock_minute_hand_3"/>

    <com.l_es.analogclockcustomization.AnalogClockDesign
        android:id="@+id/AnalogClock2"
        android:layout_
        android:layout_
        app:showSecondHand="false"
        app:dial="@drawable/clock_dial_4"
        app:hour="@drawable/clock_hour_hand_4"
        app:minute="@drawable/clock_minute_hand_4"/>

</RelativeLayout>

clock_widget.xml:

<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    android:initialLayout="@layout/clock_widget_layout"
    android:minWidth="146dp"
    android:minHeight="146dp"
    android:previewImage="@mipmap/ic_launcher"
    android:resizeMode="vertical|horizontal"
    android:updatePeriodMillis="0"
    android:widgetCategory="home_screen">
</appwidget-provider>

【问题讨论】:

请发布布局文件 我添加了widget布局文件,请看,谢谢 您是否在MainWidget 上覆盖了onUpdate() 在代码中可以看到,我没有,我贴了整个类,只有变量和onReceive 从哪里调用onReceive() (MainWidget)? 【参考方案1】:

检查您在 Widget 中的视图中使用的元素..

Documentation link

RemoteViews 对象(因此,App Widget)可以支持以下布局类:

框架布局

线性布局

相对布局

网格布局

还有以下小部件类:

    模拟时钟 按钮 天文钟 图像按钮 图像视图 进度条 文本视图 ViewFlipper 列表视图 网格视图 堆栈视图 AdapterViewFlipper

使用禁止的元素会导致这种情况

加载小部件时出现问题 消息,但没有说明发生在哪里。

【讨论】:

我在小部件布局上只使用了允许的布局和类,正如您在我发布的代码中看到的那样 com.l_es.analogclockcustomization.AnalogClockDesign 这是上面列表中没有的布局,但在您的clock_widget_layout.xml中 它而不是您在列表中指定的 AnalogClock,b/c 不推荐使用 AnalogClock 我采用原始代码并使用它而不是 android 库 您必须完全使用这些类 - 您不能创建与 RemoteViews 一起使用的 AnalogClock 的副本。 AnalogClock 已弃用,我该如何使用它?我使用了来自 android 开发者网站的完全相同的代码 1 到 1

以上是关于Android问题加载小部件-logcat中没有错误的主要内容,如果未能解决你的问题,请参考以下文章

Android 无法使用列表视图加载主屏幕小部件

需要获取数据的 Android 小部件仅显示加载

带有 ListView 的 Android 小部件无法正确加载项目

如何将图像从 url 加载到小部件的 android 远程视图中

Android:将位图从本地存储加载到应用小部件(RemoteViews)

ActivityNotFoundException 意图 + 小部件