android:如何向窗口小部件添加自定义图像?

时间:2012-02-20 10:02:50

标签: android graphics drawable

我是在Android中创建/修改任何类型的图像的新手。我想要做的是以下几点:

我有一个小部件,它会定期从广播接收器更新。事情是,我想在这个小部件中显示一个自制的(即以编程方式创建的)图像。我实际上不知道如何将图像添加到窗口小部件布局。 谁能帮我吗?下面是更新小部件的代码:

public class MyReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context.getApplicationContext());

        int[] allWidgetIds = intent.getIntArrayExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS);

        // DO SOME THINGS...

        ComponentName myWidget = new ComponentName(context.getApplicationContext(), MyWidgetProvider.class);

        int[] allMyWidgetIds = appWidgetManager.getAppWidgetIds(myWidget);  

        for (int widgetId : allMyWidgetIds) {
            RemoteViews rViews = new RemoteViews(context.getPackageName(), R.layout.widget_layout);
            rViews.setTextViewText(R.id.TextView01, "xyz"); // this works just fine, i.e. it gets updated as intended :)

            appWidgetManager.updateAppWidget(widgetId, rViews);
        }

        // set next update
        Calendar c = Calendar.getInstance();
        c.add(Calendar.SECOND, Config.UPDATE_RATE);

        Date d = new Date(c.getTimeInMillis());
        Intent i = new Intent(context.getApplicationContext(), MyReceiver.class);

        i.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, allWidgetIds);
        PendingIntent sender = PendingIntent.getBroadcast(context.getApplicationContext(), 0, i, PendingIntent.FLAG_UPDATE_CURRENT);

        AlarmManager aManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        aManager.set(AlarmManager.RTC, d.getTime(), sender);
    }
}

所以这很好用。在将“xyz”写入TextView的行中,我之前(在广播接收器中)组装的数据按预期显示,即得到更新。 在这一点上,我想“绘制”这些数据,即创建一个应该在小部件中显示的图形。

但是:我该怎么做?我猜我到底会有一个抽签。我如何实际将这个显示在窗口小部件中(当然也会更新)?

更新:

这是应该执行图形的视图类。到目前为止它只是画了一条短线。如果我通过活动中的setContentView()将其设置为视图,则此方法有效:

public class Chart extends View {   
    public Chart(Context context) {
        super(context);
    }

    @Override
    public void onDraw(Canvas canvas) {
        canvas.drawColor(Color.WHITE);

        Paint paint = new Paint();
        paint.setFlags(Paint.ANTI_ALIAS_FLAG);
        paint.setColor(Color.BLACK);

        canvas.drawLine(0, 0, 30, 30, paint);
    }
}

小部件的布局非常无聊:

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/widget_layout"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_margin="8dip"
    android:background="@drawable/traffic_shape" >
    <TextView
        android:id="@+id/TextView01"
        android:text="test"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    </TextView>
    <ImageView 
        android:id="@+id/graph"
        android:contentDescription="blah"
        android:src="@drawable/icon"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    </ImageView>
</LinearLayout>

如何在我的Chart-class中创建的视图显示在窗口小部件中?不幸的是,RemoteViews没有提供设置视图的任何功能,因为它似乎...... :(

1 个答案:

答案 0 :(得分:1)

看起来我必须回答我自己的问题。在经历了与代码挣扎的痛苦时间之后找到了答案:(

for (int widgetId : allWidgetIds)
{
    RemoteViews rViews = new RemoteViews(context.getPackageName(), R.layout.widget_layout);

    Graph graph = new Graph();
    rViews.setImageViewBitmap(R.id.graph, graph.getBitmap());

    appWidgetManager.updateAppWidget(widgetId, rViews);
}

使用Graph.java就像这样:

public class Graph {
    public Bitmap getBitmap() {
        Bitmap bitmap = Bitmap.createBitmap(128, 128, Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(bitmap);

        canvas.drawColor(Color.WHITE);

        Paint paint = new Paint();

        paint.setFlags(Paint.ANTI_ALIAS_FLAG);
        paint.setColor(Color.RED);
        canvas.drawLine(0, 0, 128, 128, paint);
        return bitmap;
    }
}