java - 有什么方法可以重构这段代码或以紧凑的形式重写它吗?

标签 java android refactoring

我正在开发一个可以在图像上产生图像效果的 Android 应用程序。 下面是我的应用程序的快照:

如您所见,底部有一个水平滚动条,当用户触摸水平滚动条上的其中一张图片时,上面的图片会应用相同的效果。

我总共有 26 个图像效果,因此水平滚动条中有 26 个图像。现在,在我的代码中,我必须找到所有这些图像并将它们的 onClickListener() 设置为一个特定的监听器。

我正在通过以下方式完成任务:

    sepiaGreenishImage      = (ImageView) findViewById(R.id.sepiaGreenish);
    embossImage             = (ImageView) findViewById(R.id.emboss);
    sharpenImage            = (ImageView) findViewById(R.id.sharpen);
    slightYellowishImage    = (ImageView) findViewById(R.id.ligth_yellow);
    slightBluishImage       = (ImageView) findViewById(R.id.light_blue);
    slightReddishImage      = (ImageView) findViewById(R.id.light_red);
    slightGreenishImage     = (ImageView) findViewById(R.id.light_green);
    negativeImage           = (ImageView) findViewById(R.id.negative);
    greyScaleImage          = (ImageView) findViewById(R.id.greyscale);
    tintSeventyImage        = (ImageView) findViewById(R.id.tint_at_70);
    tintThirtyImage         = (ImageView) findViewById(R.id.tint_at_30);
    snowImage               = (ImageView) findViewById(R.id.snow);
    darkImage               = (ImageView) findViewById(R.id.darken);
    noiseImage              = (ImageView) findViewById(R.id.noise);
    flipImage               = (ImageView) findViewById(R.id.flip);
    rotateImage             = (ImageView) findViewById(R.id.rotate);
    gaussianBlurImage       = (ImageView) findViewById(R.id.blur);
    reddishImage            = (ImageView) findViewById(R.id.reddish);
    bluishImage             = (ImageView) findViewById(R.id.bluish);
    greenishImage           = (ImageView) findViewById(R.id.greenish);
    blackFilterImage        = (ImageView) findViewById(R.id.black_filter);
    increasedSepiaImage     = (ImageView) findViewById(R.id.increased_sepia);
    spiaBluishImage         = (ImageView) findViewById(R.id.sepia_bluish);
    brightImage             = (ImageView) findViewById(R.id.brighten);
    mirrorImage             = (ImageView) findViewById(R.id.mirror); 

然后通过以下方式,我设置了 onClickListener:

    sepiaGreenishImage.setOnClickListener(this);
    embossImage.setOnClickListener(this);
    sharpenImage.setOnClickListener(this);
    slightYellowishImage.setOnClickListener(this);
    slightBluishImage.setOnClickListener(this);
    slightReddishImage.setOnClickListener(this);
    slightGreenishImage.setOnClickListener(this);
    negativeImage.setOnClickListener(this);
    greyScaleImage.setOnClickListener(this);
    tintSeventyImage.setOnClickListener(this);
    tintThirtyImage.setOnClickListener(this);
    snowImage.setOnClickListener(this);
    darkImage.setOnClickListener(this);
    noiseImage.setOnClickListener(this);
    flipImage.setOnClickListener(this);
    rotateImage.setOnClickListener(this);
    gaussianBlurImage.setOnClickListener(this);
    reddishImage.setOnClickListener(this);
    bluishImage.setOnClickListener(this);
    greenishImage.setOnClickListener(this);
    blackFilterImage.setOnClickListener(this);
    increasedSepiaImage.setOnClickListener(this);
    spiaBluishImage.setOnClickListener(this);
    brightImage.setOnClickListener(this);
    mirrorImage.setOnClickListener(this);

现在,我的问题是如何应用任何类型的重构?因为我经常重复自己。任何类型的 foreach 循环或类似的东西都可能对我有很大帮助!

最佳答案

要以编程方式执行此操作,您可以执行以下操作:

ViewGroup buttonGroup = (ViewGroup) findViewById(R.id.image_effect_buttons);
for (int i = 0; i < buttonGroup.getChildCount(); i++) {
    ImageView imageView = (ImageView) buttonGroup.getChildAt(i);
    imageView.setOnClickListener(this);
}

其中“image_effect_buttons”是包含这些图像按钮的任何 View (猜测是 LinearLayout?)的 ID。请注意,如果 ViewGroup 包含除您要附加此监听器的 ImageView 之外的任何其他子项,这将导致问题,但这是避免显式枚举它们的最简单方法。

关于java - 有什么方法可以重构这段代码或以紧凑的形式重写它吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16376488/

相关文章:

java - MyEclipse + Maven + ActiveJDBC 如何自动运行instrumentation

java - Hibernate、Spring 和 SLF4J 绑定(bind)

android - 为什么我在 Service 中发送通知时在 build() 中出现 NullPointerException?

JAVA 8 将返回值传回同一个方法 x 次

php - 对新项目和编辑项目使用 REPLACE INTO?

java - 是否有任何开源命令行工具来重构 java 代码?

java - url openstream 中的连接过多

java - HttpClient 使用 Genymotion 模拟器卡在 Android 上

java - 错误: reached end of file while parsing

java - Activity 不显示 onClick