2013-01-04 16:01:50 +01:00
|
|
|
// Copyright (c) 2013, Thomas Goyne <plorkyeran@aegisub.org>
|
2006-01-16 22:02:54 +01:00
|
|
|
//
|
2013-01-04 16:01:50 +01:00
|
|
|
// Permission to use, copy, modify, and distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
|
|
|
// copyright notice and this permission notice appear in all copies.
|
2006-01-16 22:02:54 +01:00
|
|
|
//
|
2013-01-04 16:01:50 +01:00
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
2006-01-16 22:02:54 +01:00
|
|
|
//
|
2009-07-29 07:43:02 +02:00
|
|
|
// Aegisub Project http://www.aegisub.org/
|
|
|
|
|
|
|
|
/// @file ass_time.h
|
|
|
|
/// @see ass_time.cpp
|
|
|
|
/// @ingroup subs_storage
|
|
|
|
///
|
2006-01-16 22:02:54 +01:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2013-01-04 16:01:50 +01:00
|
|
|
#include <string>
|
2006-01-16 22:02:54 +01:00
|
|
|
|
2011-12-22 22:28:13 +01:00
|
|
|
#include <libaegisub/vfr.h>
|
|
|
|
|
2006-01-16 22:02:54 +01:00
|
|
|
class AssTime {
|
2011-12-22 22:28:41 +01:00
|
|
|
/// Time in milliseconds
|
2013-12-12 01:29:48 +01:00
|
|
|
int time = 0;
|
2006-01-16 22:02:54 +01:00
|
|
|
|
|
|
|
public:
|
2011-12-22 22:28:41 +01:00
|
|
|
AssTime(int ms = 0);
|
2013-01-04 16:01:50 +01:00
|
|
|
AssTime(std::string const& text);
|
2006-01-16 22:02:54 +01:00
|
|
|
|
2011-12-22 22:28:51 +01:00
|
|
|
/// Get millisecond, rounded to centisecond precision
|
|
|
|
operator int() const { return time / 10 * 10; }
|
|
|
|
|
2011-12-22 22:28:41 +01:00
|
|
|
int GetTimeHours() const; ///< Get the hours portion of this time
|
|
|
|
int GetTimeMinutes() const; ///< Get the minutes portion of this time
|
|
|
|
int GetTimeSeconds() const; ///< Get the seconds portion of this time
|
|
|
|
int GetTimeMiliseconds() const; ///< Get the miliseconds portion of this time
|
|
|
|
int GetTimeCentiseconds() const; ///< Get the centiseconds portion of this time
|
2007-06-19 07:04:15 +02:00
|
|
|
|
2011-12-22 22:28:41 +01:00
|
|
|
/// Return the time as a string
|
|
|
|
/// @param ms Use milliseconds precision, for non-ASS formats
|
2013-01-04 16:01:50 +01:00
|
|
|
std::string GetAssFormated(bool ms=false) const;
|
2006-01-16 22:02:54 +01:00
|
|
|
};
|
|
|
|
|
2012-03-29 21:04:36 +02:00
|
|
|
/// @class SmpteFormatter
|
|
|
|
/// @brief Convert times to and from SMPTE timecodes
|
|
|
|
class SmpteFormatter {
|
|
|
|
/// Frame rate to use
|
2011-12-22 22:28:13 +01:00
|
|
|
agi::vfr::Framerate fps;
|
2012-03-29 21:04:36 +02:00
|
|
|
/// Separator character
|
2013-01-04 16:01:50 +01:00
|
|
|
std::string sep;
|
2009-05-10 05:50:58 +02:00
|
|
|
|
|
|
|
public:
|
2013-11-21 18:13:36 +01:00
|
|
|
SmpteFormatter(agi::vfr::Framerate fps, std::string sep=":");
|
2009-05-10 05:50:58 +02:00
|
|
|
|
2011-12-22 22:22:49 +01:00
|
|
|
/// Convert an AssTime to a SMPTE timecode
|
2013-01-04 16:01:50 +01:00
|
|
|
std::string ToSMPTE(AssTime time) const;
|
2012-03-29 21:04:36 +02:00
|
|
|
/// Convert a SMPTE timecode to an AssTime
|
2013-01-04 16:01:50 +01:00
|
|
|
AssTime FromSMPTE(std::string const& str) const;
|
2009-05-10 05:50:58 +02:00
|
|
|
};
|