android-widget-ticktock

by alphamu

Count down, count up, tick... tock...

198 Stars 52 Forks Last release: Not found Apache License 2.0 11 Commits 4 Releases

Available items

No Items, yet!

The developer of this repository has not created any items for sale yet. Need a bug fixed? Help with integration? A different license? Create a request here:

Build Status Download Android Arsenal

TickTock Widget

This is a circular widget that can be used to display a count down timer or a count up timer.

TickTock Widget

How to include

compile 'com.bcgdv.asia.lib:ticktock:1.3'

Usage

    
  • tickCircleDuration
    -
    minute|total_time
    the circle completes a full circle every minute or the total time different between startTime and endTime. Default
    minute
    .
  • tickAutoFitText
    -
    boolean
    default
    true
    . The text will be automatically resized to fit in the available space.
  • tickText
    - Optional
    String
    static text to display in the middle.
  • tickTextColor
    - Optional
    color
  • tickTextSize
    - Optional
    dimension
    text size if
    tickAutoFitText
    is not used.
  • tickMiddleColor
    - Optional
    color
    the color of the center of the color. Color transparent by default.
  • tickFillRingColor
    - Optional
    color
    the color of the ring when filled. Color white by default.
  • tickEmptyRingColor
    - Optional
    color
    the color of the ring when empty. Color blue by default.
  • tickRingThickness
    - Optional
    dimension
    the tickness of the ring in DIP. 3dp by default.
  • tickDotRadius
    - Optional
    dimension
    the radious in DIP of the dot. 6dp by default.
  • tickMoveCounterClockwise
    Optional
    boolean
    false by default.
public void onCreate(Bundle savedInstanceState) {
...
    mCountDown = (TickTockView) findViewById(R.id.view_ticktock_countdown);
    mCountUp = (TickTockView) findViewById(R.id.view_ticktock_countup);
    if (mCountDown != null) {
        mCountDown.setOnTickListener(new TickTockView.OnTickListener() {
            @Override
            public String getText(long timeRemaining) {
                int seconds = (int) (timeRemaining / 1000) % 60;
                int minutes = (int) ((timeRemaining / (1000 * 60)) % 60);
                int hours = (int) ((timeRemaining / (1000 * 60 * 60)) % 24);
                int days = (int) (timeRemaining / (1000 * 60 * 60 * 24));
                boolean hasDays = days > 0;
                return String.format("%1$02d%4$s %2$02d%5$s %3$02d%6$s",
                        hasDays ? days : hours,
                        hasDays ? hours : minutes,
                        hasDays ? minutes : seconds,
                        hasDays ? "d" : "h",
                        hasDays ? "h" : "m",
                        hasDays ? "m" : "s");
            }
        });
    }

if (mCountUp != null) {
    mCountUp.setOnTickListener(new TickTockView.OnTickListener() {
        SimpleDateFormat format = new SimpleDateFormat("hh:mm:ss");
        Date date = new Date();
        @Override
        public String getText(long timeRemaining) {
            date.setTime(System.currentTimeMillis());
            return format.format(date);
        }
    });
}

... }

@Override protected void onStart() { super.onStart(); Calendar end = Calendar.getInstance(); end.add(Calendar.MINUTE, 4); end.add(Calendar.SECOND, 5);

Calendar start = Calendar.getInstance();
start.add(Calendar.MINUTE, -1);
if (mCountDown != null) {
    mCountDown.start(start, end);
}

Calendar c2= Calendar.getInstance();
c2.add(Calendar.HOUR, 2);
c2.set(Calendar.MINUTE, 0);
c2.set(Calendar.SECOND, 0);
c2.set(Calendar.MILLISECOND, 0);
if (mCountUp != null) {
    mCountUp.start(c2);
}

}

@Override protected void onStop() { super.onStop(); mCountDown.stop(); mCountUp.stop(); }

Known Issues

  • Please report any through GitHub issue tracker.

License

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.