Android ImageView点击选中后添加边框

ImageView点击选中后添加边框是最近做连连看时遇到的一个小需求,从网上搜了一下,发现有用Selector做的,有用Canvas做的,但是它们都没能满足我的需求。所以,我就思考寻找其他的解决方法,经过尝试找到了一种实现的方法,具体的方法如下:1、制作一个和ImageView中要显示的图片一样大小的透明图片。2、通过绘图工具给透明图片画上边框。3、把ImageView要显示的图片设置成backgroud。4、给ImageView添加点击事件处理,动态将带边框的透明图片加入ImageView。下面就把代码和效果图展示给大家。

 

1. MainActivity.java

package com.htt.lianliankangame;

import android.content.Context;
import android.content.res.Resources;
import android.graphics.Color;
import android.graphics.drawable.GradientDrawable;
import android.os.Build;
import android.os.Bundle;
import android.support.annotation.ColorInt;
import android.support.annotation.RequiresApi;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.Toolbar;
import android.util.DisplayMetrics;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.view.ViewGroup;
import android.view.WindowManager;
import android.widget.BaseAdapter;
import android.widget.GridLayout;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.Random;

import static com.htt.lianliankangame.R.*;
import static com.htt.lianliankangame.R.drawable.background_border;

public class MainActivity extends AppCompatActivity implements View.OnClickListener{
    GridLayout gridView;
    ImageView imageView;
    ImageView currentImage;
    int dpScale;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(id.toolbar);
        setSupportActionBar(toolbar);
        DisplayMetrics metrics = new DisplayMetrics();
        getWindowManager().getDefaultDisplay().getMetrics(metrics);
        dpScale = (int)metrics.density;

        FloatingActionButton fab = (FloatingActionButton) findViewById(id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            }
        });
        //动态绘制64个带不同图片的网格
        addImageView();

    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.Game_difficult) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }

    public void addImageView(){
        gridView = (GridLayout)findViewById(id.gridLayout);
        for(int i = 0; i < 64; i++){
            imageView = new ImageView(this);
            //为每一个网格设置一个ID,然后给每一个网格附随机的图片,网格与图片之间是相互分离的
            imageView.setId(i);
            //随机产生一个数,然后通过这个数去获取图片
            int random = getRandom();
            switch (random){
                case 1:
                    imageView.setBackgroundResource(drawable.icon_1);
                    break;
                case 2:
                    imageView.setBackgroundResource(drawable.icon_2);
                    break;
                case 3:
                    imageView.setBackgroundResource(drawable.icon_3);
                    break;
                case 4:
                    imageView.setBackgroundResource(drawable.icon_4);
                    break;
                case 5:
                    imageView.setBackgroundResource(drawable.icon_5);
                    break;
                case 6:
                    imageView.setBackgroundResource(drawable.icon_6);
                    break;
                case 7:
                    imageView.setBackgroundResource(drawable.icon_7);
                    break;
                case 8:
                    imageView.setBackgroundResource(drawable.icon_8);
                    break;
            }
            ViewGroup.LayoutParams params = new GridLayout.LayoutParams();
            imageView.setLayoutParams(new LinearLayout.LayoutParams(125,125));
            imageView.setClickable(true);
            //为每一个imageView设置监听事件
            imageView.setOnClickListener(this);
            gridView.addView(imageView);
        }
    }

    public int getRandom(){
        Random random = new Random();//定义随机类
        int result = random.nextInt(8);
        return result+1;
    }

    @RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
    @Override
    public void onClick(View v) {
        handleImageView((ImageView)v);

    }

    public void handleImageView(ImageView imageView){
        imageView.setImageResource(drawable.background_border);
        currentImage = imageView;
    }


}

2. background_border.xml

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    >
    <solid android:theme="@android:style/Theme.Translucent" />
    <stroke android:width="2dp" android:color="#99ccff" />
    <corners android:radius="0dp" />
    <padding android:left="0dp" android:top="0dp"
        android:right="0dp" android:bottom="0dp" />
</shape>

3. 运行后效果图

 

 

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Coding101

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值