java - 简化从 GridView 加载绘图

标签 java android gridview imageview

我项目的drawable文件夹中有大量资源,所有这些资源都显示在GridView中,现在当用户从GridView中选择图片时图像应该加载并显示在屏幕上。问题是我的类(class)变得非常大,只需要做一个面向“if”的编程就可以知道单击了哪个图像。我相信有一种更有效的方法可以使用 HashMap 或类似的方法来加载资源。

这里有一个只有一个菜单的小例子:

secondList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> arg20, View arg21, int arg22, long arg23) {
                clearbackground2();
                arg21.setBackgroundResource(R.drawable.fondoselected);
                ((TextView) arg21.findViewById(R.id.textoItem)).setTextColor(Color.parseColor("#8fb5e3"));
                if (arg22 == 0) {
                    final int menuSecondSelected = arg22;
                    txtThirdTitleList.setText("Curvas");
                    thirdList.setAdapter(new SketchMenuSideAdapter((Activity) view.getContext(), getResources().getStringArray(R.array.viaCurva), getResources().obtainTypedArray(R.array.viaCurvaIcon), 3));
                    thirdList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
                        @Override
                        public void onItemClick(AdapterView<?> argTrh20, View argTrh21, int arg22, long arg2Trh3) {
                            if (arg22 == 0) {
                                addNewImage(menuSecondSelected, "1carril", null, null);
                            }
                            if (arg22 == 1) {
                                addNewImage(menuSecondSelected, "2carriles", null, null);
                            }
                            if (arg22 == 2) {
                                addNewImage(menuSecondSelected, "3carriles", null, null);
                            }
                            if (arg22 == 3) {
                                addNewImage(menuSecondSelected, "abierta1", null, null);
                            }
                            if (arg22 == 4) {
                                addNewImage(menuSecondSelected, "abierta2", null, null);
                            }
                            if (arg22 == 5) {
                                addNewImage(menuSecondSelected, "abierta3", null, null);
                            }
                            if (arg22 == 6) {
                                addNewImage(menuSecondSelected, "abierta4", null, null);
                            }
                            if (arg22 == 7) {
                                addNewImage(menuSecondSelected, "abierta5", null, null);
                            }
                            if (arg22 == 8) {
                                addNewImage(menuSecondSelected, "cerrada1", null, null);
                            }
                            if (arg22 == 9) {
                                addNewImage(menuSecondSelected, "cerrada2", null, null);
                            }
                            if (arg22 == 10) {
                                addNewImage(menuSecondSelected, "cerrada3", null, null);
                            }
                            if (arg22 == 11) {
                                addNewImage(menuSecondSelected, "cerrada4", null, null);
                            }
                            if (arg22 == 12) {
                                addNewImage(menuSecondSelected, "cerrada5", null, null);
                            }
                            if (arg22 == 13) {
                                addNewImage(menuSecondSelected, "carril1", null, null);
                            }
                            if (arg22 == 14) {
                                addNewImage(menuSecondSelected, "carril2", null, null);
                            }
                            if (arg22 == 15) {
                                addNewImage(menuSecondSelected, "carril3", null, null);
                            }
                            if (arg22 == 16) {
                                addNewImage(menuSecondSelected, "carril4", null, null);
                            }
                            if (arg22 == 17) {
                                addNewImage(menuSecondSelected, "carril5", null, null);
                            }
                            if (arg22 == 18) {
                                addNewImage(menuSecondSelected, "carril6", null, null);
                            }
                        }
                    });
                }

只有这种菜单大约有 6000 行,有人可以建议更好的方法吗?

最佳答案

我建议使用 SparseArray .它是Android平台中将整数映射到对象的集合。在功能上它等于 Map<Integer, Object> . HashMap(稍微)更快,但 SparseArray 针对内存使用进行了优化。

这提高了可读性,因为您只需定义和填充 map 一次,然后只需使用一种方法即可获得相应的值。

SparseArray<String> menuMap = new SparseArray<>();
menuMap.put(0, "1carril");
menuMap.put(1, "2carril");
menuMap.put(2, "3carril");
menuMap.put(3, "abierta1");
menuMap.put(4, "abierta2");
menuMap.put(5, "abierta3");
menuMap.put(6, "abierta4");
menuMap.put(7, "abierta5");
menuMap.put(8, "carril1");
menuMap.put(9, "carril2");
menuMap.put(10, "carril3");

然后在你需要的地方获取映射值:

@Override
public void onItemClick(AdapterView<?> argTrh20, View argTrh21, int arg22, long arg2Trh3) {
    String value = menuMap.get(arg22);
    if(value != null) {
        addNewImage(menuSecondSelected, value, null, null);
    }
}

如果您有足够的元素,这将是合适的。这将大大增加您需要值的地方的可读性。您仍然必须首先将所有对添加到 map 中,但这可以通过其他方式完成(即使在其他一些类中)。您还可以更轻松地更改或添加新值。

就效率而言:您至少应该使用 if-else 或 switch 语句。除此之外,它不会有太大变化,如果有足够的项目,它甚至可能会倾向于 map 。但这在这里不应该是一个真正的问题。可读性和可维护性比微小的效率差异更重要。


编辑:它实际上可以更短。我现在才意识到 arg22只是列表中的位置。
首先,适本地命名您的参数。 argTrh20 , argTrh21arg22都是可怕的名字。
但是,因为位置总是介于 0 和某个值之间,所以您可以只使用数组。您不需要将整数映射到值,因为它可以只是数组中的位置。
现在您可以用更少的行和更少的不必要代码来定义它:

String[] menuValues = {"1carril", "2carril", "3carril", "rest here", "..." };

获取值(value)现在减少为:

@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
    if(position < menuValues.length) { // this is just a defensive check. If you are sure the array is the same length as the max amount of items, this can be omitted.
        addNewImage(menuSecondSelected, menuValues[position], null, null);
    }
}

希望对你有帮助

关于java - 简化从 GridView 加载绘图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43621448/

相关文章:

java - 如何使用java对象发送请求上传文件,例如@RequestParam CommonsMultipartFile file,@RequestBody User userDetailsId?

java - 我们可以不在 Trie 构造函数中初始化引用数组吗

android - 房间数据库无法返回 group_concat 列

java - 当尝试从视频 View 中的 url 播放视频时,我收到 FileNotFoundException : No content provider error on SOME phones

c# - ASP.NET 编译错误(无法调用代码隐藏文件中的方法)

java - 为什么 Twitter 无法在 1 小时内处理多个请求?

java - 为什么我的实体管理器返回空结果列表?

android - Foundation 6 移动搜索栏在 Android 上粘在底部

带分隔符的 Android GridView

Android GridView 奇怪的项目放置