自定義View--時鐘 實戰(zhàn)

效果

device-2017-04-18-175739.png

思路

  1. 先繪制刻度和文字梢睛,通過旋轉畫布來操作
//移動畫布到屏幕正中間
      canvas.translate(getMeasuredWidth() / 2, getMeasuredHeight() / 2);
      //當前數字
      int currentP = 0;
      //繪制的數字
      String text = "";
      int len;
      for (int i = 0; i < 360 / fixAngle; i++) {
          if (i % 5 == 0) {
              if (currentP == 0) {
                  text = "12";
              } else {
                  text = currentP + "";
              }
              currentP++;
              mArcPaint.setColor(Color.BLUE);
              mArcPaint.setTextSize(40);
              mArcPaint.getTextBounds(text, 0, text.length(), mTextBound);
              canvas.drawText(text, 0, text.length(), -mTextBound.width() / 2, -(radius + b_len + 20), mArcPaint);

              mArcPaint.setColor(Color.RED);
              len = b_len;

          } else {
              mArcPaint.setColor(Color.GREEN);
              len = s_len;
          }
          canvas.drawLine(0, -radius, 0, -(radius + len), mArcPaint);
          //旋轉畫布
          canvas.rotate(fixAngle);
      }
  1. 繪制指針
 /**
   * 畫秒針
   * @param canvas
   */
  private void drawS(Canvas canvas) {

      double angle = (s * fixAngle - 90)*Math.PI/180;
      int mSecondLen = 280;
      int startX = -(int) (len * Math.cos(angle));
      int startY = -(int) (len * Math.sin(angle));

      int endX = (int) ((mSecondLen - len) * Math.cos(angle));
      int endY = (int) ((mSecondLen - len) * Math.sin(angle));
      canvas.drawLine(startX, startY, endX, endY, sPaint);

  }

  /**
   * 畫分針
   * @param canvas
   */
  private void drawM(Canvas canvas) {
      double angle = (m * 6 - 90)*Math.PI/180;
      int mMinLen = 250;
      int startX = -(int) (len * Math.cos(angle));
      int startY = -(int) (len * Math.sin(angle));

      int endX = (int) ((mMinLen - len) * Math.cos(angle));
      int endY = (int) ((mMinLen - len) * Math.sin(angle));
      canvas.drawLine(startX, startY, endX, endY, minPaint);
  }

  /**
   * 畫時針
   * @param canvas
   */
  private void drawH(Canvas canvas) {

      double angle = (h * 6 * 5 - 90)*Math.PI/180+((m *1.0f/60 *30)*Math.PI/180);
      int mHourLen = 230;
      int startX = -(int) (len * Math.cos(angle));
      int startY = -(int) (len * Math.sin(angle));

      int endX = (int) ((mHourLen - len) * Math.cos(angle));
      int endY = (int) ((mHourLen - len) * Math.sin(angle));
      canvas.drawLine(startX, startY, endX, endY, hPaint);
  }
  1. 繪制中心原點
private void drawPoint(Canvas canvas) {
      mArcPaint.setColor(Color.WHITE);
      canvas.drawCircle(0, 0, 10, mArcPaint);
  }

遇到的問題

怎么實時刷新時間 讓指針轉起來绝葡?

方案一

  1. 繼承自View
  2. 開線程,添加一個循環(huán)腹鹉,然后通過handler 去調用invalidate()

結果:打開界面幾秒后 app 直接崩潰

方案二

  1. 繼承自View
  2. onDraw()內加入以下代碼
@Override
  protected void onDraw(Canvas canvas) {
      .....

      postInvalidateDelayed(1000);
      invalidate();
  }

結果:其實就是一個死循環(huán),效果是出來了愉阎,但是內存抖動特別厲害,頻繁的觸發(fā)GC力奋,

Paste_Image.png

去掉代碼 invalidate(); 后可以正常出效果,內存也正常景殷。

方案三

  1. 繼承自 SurfaceView
  2. 緩存一個圖層
private void drawUI() {
      try {
          canvas = mSurfaceHolder.lockCanvas();
          //緩存一個圖層
          if (bitmapCache == null) {
              bitmapCache = Bitmap.createBitmap(canvas.getWidth(), canvas.getHeight(), Bitmap.Config.ARGB_4444);
          }
          canvas1 = new Canvas(bitmapCache);
          canvas1.drawColor(Color.BLACK);
          drawCanvas(canvas1);
          canvas.drawBitmap(bitmapCache, 0, 0, mPaint);
      } catch (Exception e) {
          e.printStackTrace();
      } finally {
          try {
              mSurfaceHolder.unlockCanvasAndPost(canvas);
          } catch (Exception e) {
              e.printStackTrace();
          }
      }
  }

結果:實現效果澡屡,內存也還比較穩(wěn)定

Paste_Image.png

代碼地址

https://github.com/FeeAlan/ClockView

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末藕届,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子休偶,更是在濱河造成了極大的恐慌,老刑警劉巖踏兜,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異碱妆,居然都是意外死亡肉盹,警方通過查閱死者的電腦和手機疹尾,發(fā)現死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來纳本,“玉大人窍蓝,你說我怎么就攤上這事繁成∠朋希” “怎么了巾腕?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長尊搬。 經常有香客問我叁鉴,道長毁嗦,這世上最難降的妖魔是什么亲茅? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任狗准,我火速辦了婚禮茵肃,結果婚禮上腔长,老公的妹妹穿的比我還像新娘验残。我一直安慰自己捞附,他們只是感情好,可當我...
    茶點故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布鸟召。 她就那樣靜靜地躺著,像睡著了一般欧募。 火紅的嫁衣襯著肌膚如雪压状。 梳的紋絲不亂的頭發(fā)上跟继,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天,我揣著相機與錄音舔糖,去河邊找鬼娱两。 笑死金吗,一個胖子當著我的面吹牛十兢,可吹牛的內容都是我干的摇庙。 我是一名探鬼主播旱物,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼跟匆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了玛臂?” 一聲冷哼從身側響起烤蜕,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤迹冤,失蹤者是張志新(化名)和其女友劉穎讽营,沒想到半個月后泡徙,有當地人在樹林里發(fā)現了一具尸體橱鹏,經...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡堪藐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了礁竞。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,654評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡模捂,死狀恐怖蜘矢,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情综看,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布红碑,位于F島的核電站,受9級特大地震影響句喷,放射性物質發(fā)生泄漏镣典。R本人自食惡果不足惜唾琼,卻給世界環(huán)境...
    茶點故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一兄春、第九天 我趴在偏房一處隱蔽的房頂上張望锡溯。 院中可真熱鬧赶舆,春花似錦祭饭、人聲如沸芜茵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽寺鸥。三九已至猪钮,卻和暖如春胆建,著一層夾襖步出監(jiān)牢的瞬間烤低,已是汗流浹背笆载。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工扑馁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留凉驻,地道東北人腻要。 一個月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓涝登,卻偏偏與公主長得像闯第,于是被迫代替她去往敵國和親缀拭。 傳聞我的和親對象是個殘疾皇子咳短,可洞房花燭夜當晚...
    茶點故事閱讀 43,543評論 2 349

推薦閱讀更多精彩內容