Android 自定義View-組合自定義-日歷控件

本文出自簡書:堯沐,如需轉載請標明出處,尊重原創(chuàng)謝謝
博客地址:http://www.itdecent.cn/p/6f40fb8d64e6
自定義View學習很久了,一直想寫點什么鞏固一下自己,從最簡單的自定一個日歷開始吧
組合控件就是用系統(tǒng)已經封裝好的東西然后加以組合形成一個我們需要的東西,相對于各種畫出來的簡單很多很多。由易到難

1507346319(1).jpg

首先我們看一下日歷-沒錯這就是win10自帶的 注意看紅色字體,是每個地方的組成,這么一看是不是簡單很多很多

接下來寫布局- -寫布局注意幾點 不要嵌套很深,這樣解析會慢(最近看書學的優(yōu)化~ ~)
說實在的很不想寫布局這種東西 麻煩的一逼 你就當我寫好了吧- -

因為是組合控件 所以就不是繼承VIew 而是一個布局 我這里繼承線性布局

然后實現(xiàn)三個構造方法

   @RequiresApi(api = Build.VERSION_CODES.N)
    public DataView(Context context) {
        super(context);
        initFindIdAndLinsen(context);
    }

    @RequiresApi(api = Build.VERSION_CODES.N)
    public DataView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
        initFindIdAndLinsen(context);
    }

    @RequiresApi(api = Build.VERSION_CODES.N)
    public DataView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        initFindIdAndLinsen(context);
    }

initFindIdAndLinsen 這個方法是綁定控件以及設置監(jiān)聽
里面的代碼很簡單

    @RequiresApi(api = Build.VERSION_CODES.N)
    private void initFindIdAndLinsen(final Context context) {
        LayoutInflater inflater = LayoutInflater.from(context);
        inflater.inflate(R.layout.view_calendar, this);

        mWeekUp = (ImageView) findViewById(R.id.week_up);
        mWeeknExt = (ImageView) findViewById(R.id.weekn_ext);
        mWeekToday = (TextView) findViewById(R.id.week_today);
        mWeekRecy = (RecyclerView) findViewById(R.id.week_recy);

        renderCalender(context);

        mWeekUp.setOnClickListener(new OnClickListener() {
            @RequiresApi(api = Build.VERSION_CODES.N)
            @Override
            public void onClick(View v) {
                calendata.add(Calendar.MONTH, -1);
                renderCalender(context);
            }


        });
        mWeeknExt.setOnClickListener(new OnClickListener() {
            @RequiresApi(api = Build.VERSION_CODES.N)
            @Override
            public void onClick(View v) {
                calendata.add(Calendar.MONTH, 1);
                renderCalender(context);
            }
        });
    }

這些都沒什么好說的對吧,其實難點就一個 就是日期的計算


1507346319(1).jpg

注意看,我這個月的第一天是1號 他在星期日的位置 主要就是這個的計算,這個要怎么算呢

   /**
     * 渲染界面
     *
     * @param context
     */

    @RequiresApi(api = Build.VERSION_CODES.N)
    private void renderCalender(Context context) {
        /**
         * 時間格式化
         */
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("MM yyyy");
        mWeekToday.setText(simpleDateFormat.format(calendata.getTime()));

        /**
         * 為了不污染 本身的時間所以復制一個
         */
        Calendar calendarOne = (Calendar) calendata.clone();
        List<Date> mDate = new ArrayList<>();

        /**
         * 把日期放在第一天 然后看最后一個周末剩下幾天 然后位移
         */
        calendarOne.set(Calendar.DAY_OF_MONTH, 1);
        calendarOne.add(Calendar.DAY_OF_MONTH, - calendarOne.get(Calendar.DAY_OF_WEEK) - 1);

        /**
         * 裝數據進去
         */
        while (mDate.size() < 42) {
            mDate.add(calendarOne.getTime());
            calendarOne.add(Calendar.DAY_OF_MONTH, 1);
        }

        /**
         * recylerview的Adapert總會把- -
         */
        DataViewAdapter dataViewAdapter = new DataViewAdapter(R.layout.item_data, mDate);
        mWeekRecy.setAdapter(dataViewAdapter);
        GridLayoutManager gridLayoutManager = new GridLayoutManager(context, 7);
        mWeekRecy.setLayoutManager(gridLayoutManager);
    }

這樣這個控件就好了,難的地方就在怎么算日期上面 - -

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,881評論 25 709
  • 發(fā)現(xiàn) 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 15,157評論 4 61
  • 早上起來看兒子房間的燈亮著,在廚房做飯的時候兒子說要吃熱干面,我問他要對他狠心的話是否當真?他沒有回答,但拒絕下樓...
    周華14134閱讀 383評論 1 3
  • 給wuli倩倩 今天是1月19日22:43,剛和我家倩倩道完晚安。突然好想寫點什么,給她。 我們關系很好,幾乎所有...
    劉小明閱讀 857評論 0 1
  • 嗯~今天我們換風格了講兩只小雞仔的故事,四不四很期待(挑眉) 人物有:小黃,小仔 (一天早上,大雪紛飛~不用說,冬...
    兮fany閱讀 456評論 0 1

友情鏈接更多精彩內容