自定義view 之多個(gè)引導(dǎo)層動(dòng)畫(huà)效果

SupernatantView

  • 如果我英文還可以的話這個(gè)應(yīng)該叫做漂浮在上層的view---引導(dǎo)層
  • 今天閑來(lái)無(wú)事看了網(wǎng)上的一些引導(dǎo)層案例總感覺(jué)如果不是很舒服,就是類(lèi)似于很死板的顯示和消失
  • 我在想能不能弄點(diǎn)動(dòng)畫(huà)上去看著舒服一些 所以就有了以下的gif gif有點(diǎn)短但是沒(méi)辦法太長(zhǎng)了github傳不上去 不知道是不是我操作不太對(duì)
Markdown
  • 剛開(kāi)始點(diǎn)擊屏幕是沒(méi)有反應(yīng)的 因?yàn)槲野腰c(diǎn)擊事件攔截了 后面代碼可以看得到
  • 因?yàn)槲覀儺a(chǎn)品汪沒(méi)有這樣的需求 所以我有的地方寫(xiě)的不是很?chē)?yán)謹(jǐn) 包括指示箭頭在下方如果下方距離不夠箭頭顯示的時(shí)候 我也沒(méi)有做判斷 只是把大體的意思寫(xiě)出來(lái)了 大家如果想更改 可以看里邊的注釋 (偷偷告訴你們里邊注釋賊多 不怕你看不懂)
  • step 1

    繼承view 重寫(xiě)構(gòu)造方法 和 onTouchEvent 和 draw 方法

      public SupernatantView(Context context) {
            this(context, null);
        }
    
        public SupernatantView(Context context, AttributeSet attrs) {
            this(context, attrs, 0);
        }
    
        public SupernatantView(Context context, AttributeSet attrs, int defStyleAttr) {
           super(context, attrs, defStyleAttr);
    
        }
    

    onDraw 方法

          @Override
      protected void onDraw(Canvas canvas) {
       super.onDraw(canvas);
      }
    

    onTouchEvent方法

           @Override
        public boolean onTouchEvent(MotionEvent event) {
    
      //        return super.onTouchEvent(event);
      return true;  //攔截點(diǎn)擊事件
       }
    
  • step 2

    初始化畫(huà)筆方法 單獨(dú)抽取出來(lái)

      private Paint createPaint(int paintColor, int alpha, int textSize, Paint.Style style, int linWidth) {
      Paint paint = new Paint();                  //初始化畫(huà)筆
      paint.setAntiAlias(true);                   //抗鋸齒
      paint.setDither(true);                      //防抖動(dòng)
      paint.setStrokeCap(Paint.Cap.ROUND);        //筆觸風(fēng)格為圓角
      paint.setStrokeJoin(Paint.Join.ROUND);      //結(jié)合處形狀為圓角
      paint.setColor(paintColor);                 //設(shè)置顏色
      paint.setAlpha(alpha);                      //設(shè)置透明度
      paint.setTextSize(textSize);                //設(shè)置文字大小
      paint.setStyle(style);                      //設(shè)置樣式
      paint.setStrokeWidth(linWidth);             //設(shè)置邊寬度
      return paint;
        } 
    
  • step 3

    初始化各種數(shù)值 包括 屏幕的寬高 狀態(tài)欄

       public static int[] getScreenSize(Context context) {
      DisplayMetrics metrics = new DisplayMetrics();
      WindowManager windowManager = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE);
      windowManager.getDefaultDisplay().getMetrics(metrics);
      return new int[]{metrics.widthPixels, metrics.heightPixels};
       }
    
       public static int getStatusBarHeight() {
      return Resources.getSystem().getDimensionPixelSize(
              Resources.getSystem().getIdentifier("status_bar_height", "dimen", "android"));
         }
    
  • step 4

    一些基本的方法包括獲取view 的屏幕坐標(biāo),獲取view 的 RectF 具體在代碼里會(huì)有詳細(xì)的注釋 給你先看個(gè)圖片 沒(méi)錯(cuò)就是這么詳細(xì) 哦哈哈哈~~~

Markdown
  • step 5

    就是重寫(xiě)onDraw方法了 再加上計(jì)算一些動(dòng)態(tài)數(shù)據(jù)之類(lèi)的 代碼太多就不貼出來(lái)了 大家如果感興趣可以看看


github風(fēng)火輪:https://github.com/guanhaoran/SupernatantView

QQ 765307272

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末肥卡,一起剝皮案震驚了整個(gè)濱河市早敬,隨后出現(xiàn)的幾起案子睹簇,更是在濱河造成了極大的恐慌牙捉,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件材失,死亡現(xiàn)場(chǎng)離奇詭異痕鳍,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)龙巨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)笼呆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人旨别,你說(shuō)我怎么就攤上這事诗赌。” “怎么了秸弛?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵铭若,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我递览,道長(zhǎng)叼屠,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任非迹,我火速辦了婚禮环鲤,結(jié)果婚禮上纯趋,老公的妹妹穿的比我還像新娘憎兽。我一直安慰自己,他們只是感情好吵冒,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布纯命。 她就那樣靜靜地躺著,像睡著了一般痹栖。 火紅的嫁衣襯著肌膚如雪亿汞。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,046評(píng)論 1 285
  • 那天揪阿,我揣著相機(jī)與錄音疗我,去河邊找鬼咆畏。 笑死,一個(gè)胖子當(dāng)著我的面吹牛吴裤,可吹牛的內(nèi)容都是我干的旧找。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼麦牺,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼钮蛛!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起剖膳,我...
    開(kāi)封第一講書(shū)人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤魏颓,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后吱晒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體甸饱,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年仑濒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了柜候。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡躏精,死狀恐怖渣刷,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情矗烛,我是刑警寧澤辅柴,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站瞭吃,受9級(jí)特大地震影響碌嘀,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜歪架,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一股冗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧和蚪,春花似錦止状、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至催束,卻和暖如春集峦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工塔淤, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留摘昌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓高蜂,卻偏偏與公主長(zhǎng)得像第焰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子妨马,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

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