/*
 * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package net.micode.notes.widget;

import android.appwidget.AppWidgetManager;
import android.content.Context;

import net.micode.notes.R;
import net.micode.notes.data.Notes;
import net.micode.notes.tool.ResourceParser;

/*
 * NoteWidgetProvider_4x 是便签应用中 4x 尺寸桌面小部件的实现类。
 * 负责处理 4x 小部件的更新、布局和样式显示逻辑。
 *
 * 4x 小部件通常占用 4 列 x 2 行的桌面空间,适合展示较长内容或更丰富的便签布局。
 */
public class NoteWidgetProvider_4x extends NoteWidgetProvider {
    /*
     * 当小部件更新时调用此方法。
     * 继承自 AppWidgetProvider,实现小部件的具体更新逻辑。
     *
     * @param context 应用上下文
     * @param appWidgetManager AppWidgetManager 实例
     * @param appWidgetIds 需要更新的小部件 ID 数组
     */
    @Override
    public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
        // 调用父类的更新方法处理通用逻辑
        super.update(context, appWidgetManager, appWidgetIds);
    }

    /*
     * 获取 4x 小部件的布局资源 ID。
     *
     * @return 返回 4x 小部件使用的布局文件资源 ID
     */
    protected int getLayoutId() {
        return R.layout.widget_4x;
    }

    /*
     * 根据背景颜色 ID 获取对应的 4x 小部件背景资源。
     *
     * @param bgId 背景颜色 ID
     * @return 返回对应的背景图片资源 ID
     */
    @Override
    protected int getBgResourceId(int bgId) {
        return ResourceParser.WidgetBgResources.getWidget4xBgResource(bgId);
    }

    /*
     * 获取当前小部件的类型。
     *
     * @return 返回标识 4x 小部件的类型常量
     */
    @Override
    protected int getWidgetType() {
        return Notes.TYPE_WIDGET_4X;
    }
}