Day12 實(shí)現(xiàn)手勢(shì)解鎖

1. MainActivity extends AppCompatActivity

實(shí)現(xiàn)圖片的添加封裝
image.png

image.png

詳細(xì)代碼

public class MainActivity extends AppCompatActivity {
 //   ArrayList<ImageView> dotlist;

    float padding;
    RelativeLayout rl;
    ArrayList<ImageView> dotViews;
    DrawView drawView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        //創(chuàng)建正常的點(diǎn)
        initNineDot(R.drawable.normal,View.VISIBLE);

        //添加一層視圖
        DrawView();

        //創(chuàng)建點(diǎn)亮的點(diǎn)
        initNineDot(R.drawable.selected,View.INVISIBLE);

        //將所有點(diǎn)的數(shù)組傳遞給DrawView
        drawView.setDotViews(dotViews);


    }

    private void DrawView(){
        drawView = new DrawView(this);

        RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);

        rl.addView(drawView, params);
    }

    private void initNineDot(int res,int visible){
        rl = findViewById(R.id.parent);
        dotViews = new ArrayList<>();

        //確定左右間距大小
        padding = piexlFromDp(50);

        //計(jì)算兩個(gè)點(diǎn)中心點(diǎn)之間的間距
        //得到屏幕寬度
        Point p = new Point();
        getWindowManager().getDefaultDisplay().getSize(p);
        //獲取圖片
        Bitmap bitmap = BitmapFactory.decodeResource(getResources(),R.drawable.normal);
        float space = (p.x - 2 * padding - bitmap.getWidth()) / 2;

        //確定第一個(gè)點(diǎn)的x,y
        float x = padding;
        float y = p.y / 2 - space - bitmap.getHeight();

        //使用for循環(huán)快速添加九個(gè)點(diǎn)
        for (int i = 0; i < 3; i++){
            for(int j = 0; j < 3; j++){

                //調(diào)用函數(shù)添加圖片
                creatDot(res,(int) (x + space * j),(int) (y + space * i),visible);

            }
        }

    }

    //將添加圖片的功能進(jìn)行封裝
    private void creatDot(int res,int left,int top,int visible){
        //創(chuàng)建圖片視圖
        ImageView iv = new ImageView(this);
        iv.setBackgroundResource(res);
        iv.setVisibility(visible);

        //創(chuàng)建容器
        RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
        params.leftMargin = left;
        params.topMargin = top;

        //添加視圖
        rl.addView(iv,params);

        //判斷res對(duì)應(yīng)的是否為selected
        if (res == R.drawable.selected){
            dotViews.add(iv);
        }

    }

    //計(jì)算dp對(duì)應(yīng)的像素值
    private float piexlFromDp(int size){
        //獲取屏幕的密度
        return size * getResources().getDisplayMetrics().density;
    }
}

2. DrawView extends View

實(shí)行主要功能劃線

詳細(xì)代碼

public class DrawView extends View {
    private ArrayList<ImageView> dotViews;
    private Point startPoint;
    private Point endPoint;
    private Paint mPaint;
    private ArrayList<Path>paths;
    private ArrayList<ImageView> selected;

    public DrawView(Context context) {
        super(context);

        mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
        mPaint.setColor(Color.WHITE);
        mPaint.setStrokeWidth(20);
        mPaint.setStyle(Paint.Style.STROKE);
        paths = new ArrayList<>();
        selected=new ArrayList<>();
    }

    public void setDotViews(ArrayList<ImageView> dotViews) {
        this.dotViews = dotViews;
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        float x = event.getX();
        float y = event.getY();

        ImageView dot;
        switch (event.getAction()){
            case MotionEvent.ACTION_DOWN:
                dot = viewContainedPoint(x,y);
                if (dot != null){
                    dot.setVisibility(VISIBLE);
                    //設(shè)置起始點(diǎn)
                    startPoint = new Point((int)(dot.getPivotX() + dot.getX()),
                            (int)(dot.getPivotY() + dot.getY()));
                }
                break;
            case MotionEvent.ACTION_MOVE:
                dot = viewContainedPoint(x,y);
                if (dot == null){
                    //劃線
                    endPoint = new Point((int)x,(int)y);
                    //刷新
                    invalidate();
                }else {
                    //判斷是第一個(gè)點(diǎn)還是其他
                    if(startPoint==null){
                        dot.setVisibility(VISIBLE);
                        //設(shè)置起始點(diǎn)
                        startPoint = new Point((int)(dot.getPivotX() + dot.getX()),
                                (int)(dot.getPivotY() + dot.getY()));
                    }else{
                        //點(diǎn)亮點(diǎn)
                        dot.setVisibility(VISIBLE);
                        //在之前和現(xiàn)在的點(diǎn)之間產(chǎn)生一個(gè)path
                        Path path=new Path();
                        path.moveTo(startPoint.x,startPoint.y);
                        path.lineTo(dot.getPivotX() + dot.getX(),
                                dot.getPivotY() + dot.getY());

                        paths.add(path);

                        //當(dāng)前這個(gè)這個(gè)點(diǎn)就是起始點(diǎn)
                        //設(shè)置起始點(diǎn)
                        startPoint = new Point((int)(dot.getPivotX() + dot.getX()),
                                (int)(dot.getPivotY() + dot.getY()));
                        endPoint=startPoint;

                        //刷新
                        invalidate();
                    }
                    selected.add(dot);
                }
                break;
            case MotionEvent.ACTION_UP:
                clear();
                break;
        }
        return true;
    }

    @Override
    protected void onDraw(Canvas canvas) {
        if (paths.size() > 0){
            for (Path path: paths){
                canvas.drawPath(path, mPaint);
            }
        }
        if (startPoint != null && endPoint != null) {
            canvas.drawLine(startPoint.x, startPoint.y,
                    endPoint.x, endPoint.y, mPaint);
        }
    }


    private void clear(){
        for (ImageView dot: selected)
        {            dot.setVisibility(INVISIBLE);
        }        selected.clear();
        paths.clear();
        startPoint = null;
        endPoint = null;
        invalidate();
    }
    //判斷觸摸點(diǎn)是否在某個(gè)dot里面
    private ImageView viewContainedPoint(float x,float y){
        for (ImageView dot: dotViews){
            int[] point = new int[2];
            dot.getLocationOnScreen(point);

            //獲取dot的x和y坐標(biāo)
            //int px = point[0];
            //int py = point[1];

            int px = (int) dot.getX();
            int py = (int) dot.getY();
            if ((x >= px && x <= px + dot.getWidth())
                    &&(y >= py && y <= py +dot.getHeight())){
                return dot;
            }
        }
        return  null;
    }
}

3.xml配置

很基礎(chǔ)


image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市缸匪,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,423評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茴迁,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡招刨,警方通過(guò)查閱死者的電腦和手機(jī)夹供,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,147評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)灵份,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人哮洽,你說(shuō)我怎么就攤上這事填渠。” “怎么了鸟辅?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,019評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵氛什,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我匪凉,道長(zhǎng)枪眉,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,443評(píng)論 1 283
  • 正文 為了忘掉前任洒缀,我火速辦了婚禮瑰谜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘树绩。我一直安慰自己萨脑,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,535評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布饺饭。 她就那樣靜靜地躺著渤早,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瘫俊。 梳的紋絲不亂的頭發(fā)上鹊杖,一...
    開(kāi)封第一講書(shū)人閱讀 49,798評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音扛芽,去河邊找鬼骂蓖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛川尖,可吹牛的內(nèi)容都是我干的登下。 我是一名探鬼主播,決...
    沈念sama閱讀 38,941評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼叮喳,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼被芳!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起馍悟,我...
    開(kāi)封第一講書(shū)人閱讀 37,704評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤畔濒,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后锣咒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體侵状,經(jīng)...
    沈念sama閱讀 44,152評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赞弥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,494評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了壹将。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嗤攻。...
    茶點(diǎn)故事閱讀 38,629評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖诽俯,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情承粤,我是刑警寧澤暴区,帶...
    沈念sama閱讀 34,295評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站辛臊,受9級(jí)特大地震影響仙粱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜彻舰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,901評(píng)論 3 313
  • 文/蒙蒙 一伐割、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧刃唤,春花似錦隔心、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至笼裳,卻和暖如春唯卖,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背躬柬。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,978評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工拜轨, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人允青。 一個(gè)月前我還...
    沈念sama閱讀 46,333評(píng)論 2 360
  • 正文 我出身青樓橄碾,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親昧廷。 傳聞我的和親對(duì)象是個(gè)殘疾皇子堪嫂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,499評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容