CompactCalendarView เป็นมุมมองปฏิทินแบบธรรมดาที่ให้การเลื่อนระหว่างเดือนต่างๆ ขึ้นอยู่กับคลาส Date และ Calendar ของ Java โดยมี API ง่ายๆ สำหรับการสืบค้นวันที่และผู้ฟังเหตุการณ์เฉพาะ ตัวอย่างเช่น เมื่อปฏิทินเลื่อนไปที่เดือนใหม่หรือเลือกวัน ยังอยู่ระหว่างการพัฒนาอย่างแข็งขัน
โปรดยกประเด็นข้อกำหนดเพื่อให้สามารถอภิปรายการได้ก่อนที่จะเขียนโค้ดใดๆ แม้ว่าคุณจะตั้งใจที่จะยื่นคำขอดึงก็ตาม โปรดดูการตั้งค่าสำหรับการทดสอบ
CompactCalendarView ใช้ประโยชน์จากภาพหน้าจอ-tests-for-android (https://github.com/facebook/screenshot-tests-for-android) นี่เป็นการทดสอบ UI เนื่องจากภาพหน้าจอทดสอบสำหรับ Android จับภาพหน้าจอ เราจึงต้องมีวิธีเพื่อให้แน่ใจว่าภาพสามารถทำซ้ำได้อย่างสม่ำเสมอ เมื่อต้องการทำเช่นนี้ จะใช้โปรแกรมจำลองเฉพาะเพื่อทำการทดสอบ น่าเสียดายที่ขณะนี้มีการใช้โปรแกรมจำลองรุ่นเก่า คำขอดึงใหม่ซึ่งเปลี่ยนฟังก์ชันการทำงาน ควรมีจุดมุ่งหมายเพื่อสร้างการทดสอบภาพหน้าจอใหม่หรือการทดสอบหน่วยหากเป็นไปได้ หากต้องการรันสิ่งนี้ในเครื่อง ให้รันคำสั่งด้านล่าง:
ข้อกำหนดเบื้องต้น (รวมถึง .travis.yml ด้วย):
มีการใช้โปรแกรมจำลอง Android 19 เนื่องจากดูเหมือนว่าจะเร็วเพียงพอบน travis-ci และเนื่องจากตัวจำลอง x86 ไม่รองรับ travis-ci เวอร์ชัน Android ที่ใหม่กว่านั้นเป็นไปได้ แต่เวลาในการสร้างจะเพิ่มขึ้น
ติดตั้ง abi และยอมรับ:
$ $ANDROID_HOME /tools/bin/sdkmanager ' system-images;android-22;default;armeabi-v7a '
สร้างโปรแกรมจำลอง:
$ echo no | $ANDROID_HOME /tools/bin/avdmanager create avd --force -n testCompactCalendarEmulator -k " system-images;android-22;default;armeabi-v7a "
สร้างการ์ด SD (สร้างใน dir ปัจจุบัน): ปัญหาใด ๆ เกี่ยวกับ sdcard ได้รับการแก้ไขได้ดีที่สุดโดยการลบแล้วลองอีกครั้ง
$ mksdcard -l sdcard 100M sdcard
เรียกใช้โปรแกรมจำลอง (โดยไม่มีเสียงและหน้าต่าง):
$ $ANDROID_HOME /emulator/emulator -avd testCompactCalendarEmulator -no-audio -no-window -sdcard sdcard &
เรียกใช้โปรแกรมจำลองและดู (พร้อมเสียงและหน้าต่าง):
$ $ANDROID_HOME /emulator/emulator -avd testCompactCalendarEmulator -sdcard sdcard
เรียกใช้การทดสอบเพื่อตรวจสอบว่าการทดสอบปัจจุบันผ่าน และเพื่อตรวจสอบว่าการทดสอบใดที่ไม่สร้างภาพหน้าจอเดียวกัน:
$ ./gradlew verifyMode screenshotTests
หากต้องการสร้างภาพหน้าจอใหม่หากมีการเพิ่มการทดสอบใหม่:
$ ./gradlew recordMode screenshotTests
รันการทดสอบหน่วยดังนี้:
$ ./gradlew test
สามารถทดสอบโดยใช้ android studio emulator ได้ อย่างไรก็ตาม ต้องเป็นความละเอียดหน้าจอ Android 19 และ 480x800 ตัวอย่างหนึ่งคือโปรแกรมจำลอง Nexus S เพียงเริ่มต้นโปรแกรมจำลองและดำเนินการคำสั่ง gradle เพื่อรันการทดสอบ ควรพบโปรแกรมจำลองโดยอัตโนมัติ
ไลบรารีรองรับการเปิด/ปิดโดยมีหรือไม่มีภาพเคลื่อนไหว
สามารถเปลี่ยนรูปลักษณ์ของมุมมองผ่านคุณสมบัติบางอย่างได้ ซึ่งรวมถึงสีพื้นหลัง สีข้อความ สีขนาดตัวอักษรของวันปัจจุบัน และสีของวันแรกของเดือน
< com .github.sundeepk.compactcalendarview.CompactCalendarView
xmlns : app = " http://schemas.android.com/apk/res-auto "
android : id = " @+id/compactcalendar_view "
android : layout_width = " fill_parent "
android : paddingRight = " 10dp "
android : paddingLeft = " 10dp "
android : layout_height = " 250dp "
app : compactCalendarTargetHeight = " 250dp "
app : compactCalendarTextSize = " 12sp "
app : compactCalendarBackgroundColor = " #ffe95451 "
app : compactCalendarTextColor = " #fff "
app : compactCalendarCurrentSelectedDayBackgroundColor = " #E57373 "
app : compactCalendarCurrentDayBackgroundColor = " #B71C1C "
app : compactCalendarMultiEventIndicatorColor = " #fff "
/>
โปรดดูตัวอย่างเต็มของแอป
// ... code omitted for brevity
@ Override
protected void onCreate ( Bundle savedInstanceState ) {
super . onCreate ( savedInstanceState );
setContentView ( R . layout . activity_main );
final CompactCalendarView compactCalendarView = ( CompactCalendarView ) findViewById ( R . id . compactcalendar_view );
// Set first day of week to Monday, defaults to Monday so calling setFirstDayOfWeek is not necessary
// Use constants provided by Java Calendar class
compactCalendarView . setFirstDayOfWeek ( Calendar . MONDAY );
// Add event 1 on Sun, 07 Jun 2015 18:20:51 GMT
Event ev1 = new Event ( Color . GREEN , 1433701251000L , "Some extra data that I want to store." );
compactCalendar . addEvent ( ev1 );
// Added event 2 GMT: Sun, 07 Jun 2015 19:10:51 GMT
Event ev2 = new Event ( Color . GREEN , 1433704251000L );
compactCalendar . addEvent ( ev2 );
// Query for events on Sun, 07 Jun 2015 GMT.
// Time is not relevant when querying for events, since events are returned by day.
// So you can pass in any arbitary DateTime and you will receive all events for that day.
List < Event > events = compactCalendar . getEvents ( 1433701251000L ); // can also take a Date object
// events has size 2 with the 2 events inserted previously
Log . d ( TAG , "Events: " + events );
// define a listener to receive callbacks when certain events happen.
compactCalendarView . setListener ( new CompactCalendarView . CompactCalendarViewListener () {
@ Override
public void onDayClick ( Date dateClicked ) {
List < Event > events = compactCalendarView . getEvents ( dateClicked );
Log . d ( TAG , "Day was clicked: " + dateClicked + " with events " + events );
}
@ Override
public void onMonthScroll ( Date firstDayOfNewMonth ) {
Log . d ( TAG , "Month was scrolled to: " + firstDayOfNewMonth );
}
});
}
คุณสามารถแก้ไขอินดิเคเตอร์ได้โดยใช้สไตล์ที่กำหนดไว้ล่วงหน้า ด้านล่างนี้คือตัวอย่าง แต่ยังสามารถใช้การผสมผสานอื่นๆ ได้อีกสองสามแบบ:
โปรดทราบว่าปฏิทินจะไม่พยายามยกเลิกการทำซ้ำกิจกรรมสำหรับ DateTime ที่เหมือนกันทุกประการ นี่คือสิ่งที่คุณต้องจัดการด้วยตนเองหากมีความสำคัญต่อกรณีการใช้งานของคุณ
คุณสามารถตั้งค่าภาษาเพื่อให้ปฏิทินตั้งชื่อคอลัมน์วันทำงานโดยอัตโนมัติได้
CompactCalendarView compactCalendarView = ( CompactCalendarView ) findViewById ( R . id . compactcalendar_view );
compactCalendarView . setLocale ( Locale . CHINESE );
compactCalendarView . setUseThreeLetterAbbreviation ( true );
dependencies {
compile ' com.github.sundeepk:compact-calendar-view:3.0.0 '
}
The MIT License (MIT)
Copyright (c) [2018] [Sundeepk]
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.