mirror of
https://github.com/RetroDECK/ES-DE.git
synced 2025-01-18 07:05:39 +00:00
Squashed 'external/rlottie/' changes from 875626965..056c0a1bc
056c0a1bc example: lottieviewer - fixed frame no (#528) 12facb817 Fix one frame missing (#529) 30f300ddc Delete accidentally committed Vim swap file git-subtree-dir: external/rlottie git-subtree-split: 056c0a1bc14bcee6f6b1a821013872a1228b0fa9
This commit is contained in:
parent
79ff784721
commit
1d638b1924
|
@ -109,7 +109,6 @@ void LottieView::seek(float pos)
|
||||||
{
|
{
|
||||||
if (!mRenderDelegate) return;
|
if (!mRenderDelegate) return;
|
||||||
|
|
||||||
|
|
||||||
mPos = mapProgress(pos);
|
mPos = mapProgress(pos);
|
||||||
|
|
||||||
// check if the pos maps to the current frame
|
// check if the pos maps to the current frame
|
||||||
|
|
|
@ -62,12 +62,13 @@ _layout_del_cb(void *data, Evas *, Evas_Object *, void *)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_update_frame_info(AppInfo *info, double pos)
|
_update_frame_info(AppInfo *info)
|
||||||
{
|
{
|
||||||
int frameNo = pos * info->view->getTotalFrame();
|
long currFrameNo = info->view->mCurFrame;
|
||||||
char buf[64];
|
long totalFrameNo = info->view->getTotalFrame();
|
||||||
|
|
||||||
sprintf(buf, "%d / %ld", frameNo, info->view->getTotalFrame());
|
char buf[64];
|
||||||
|
sprintf(buf, "%ld (total: %ld)", currFrameNo, totalFrameNo);
|
||||||
elm_object_part_text_set(info->layout, "text", buf);
|
elm_object_part_text_set(info->layout, "text", buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +97,7 @@ _animator_cb(void *data)
|
||||||
if (info && info->autoPlaying && info->view)
|
if (info && info->autoPlaying && info->view)
|
||||||
{
|
{
|
||||||
float pos = info->view->getPos();
|
float pos = info->view->getPos();
|
||||||
_update_frame_info(info, pos);
|
_update_frame_info(info);
|
||||||
elm_slider_value_set(info->slider, (double)pos);
|
elm_slider_value_set(info->slider, (double)pos);
|
||||||
evas_object_image_pixels_dirty_set(info->view->getImage(), EINA_TRUE);
|
evas_object_image_pixels_dirty_set(info->view->getImage(), EINA_TRUE);
|
||||||
if (pos >= 1.0)
|
if (pos >= 1.0)
|
||||||
|
@ -111,20 +112,20 @@ _slider_cb(void *data, Evas_Object *obj, void *event_info EINA_UNUSED)
|
||||||
double val = elm_slider_value_get(obj);
|
double val = elm_slider_value_get(obj);
|
||||||
AppInfo *info = (AppInfo *)data;
|
AppInfo *info = (AppInfo *)data;
|
||||||
|
|
||||||
_update_frame_info(info, val);
|
|
||||||
|
|
||||||
if (!info->autoPlaying)
|
if (!info->autoPlaying)
|
||||||
{
|
{
|
||||||
info->view->seek(val);
|
info->view->seek(val);
|
||||||
evas_object_image_pixels_dirty_set(info->view->getImage(), EINA_TRUE);
|
evas_object_image_pixels_dirty_set(info->view->getImage(), EINA_TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_update_frame_info(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_button_clicked_cb(void *data, Evas_Object */*obj*/, void */*event_info*/)
|
_button_clicked_cb(void *data, Evas_Object */*obj*/, void */*event_info*/)
|
||||||
{
|
{
|
||||||
AppInfo *info = (AppInfo *)data;
|
AppInfo *info = (AppInfo *)data;
|
||||||
|
if (info->view->getPos() >= 1.0f) info->view->mPos = 0.0f;
|
||||||
_toggle_start_button(info);
|
_toggle_start_button(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,7 +134,6 @@ create_layout(Evas_Object *parent, const char *file)
|
||||||
{
|
{
|
||||||
Evas_Object *layout, *slider, *image, *button;
|
Evas_Object *layout, *slider, *image, *button;
|
||||||
Ecore_Animator *animator;
|
Ecore_Animator *animator;
|
||||||
char buf[64];
|
|
||||||
AppInfo *info = (AppInfo *)calloc(sizeof(AppInfo), 1);
|
AppInfo *info = (AppInfo *)calloc(sizeof(AppInfo), 1);
|
||||||
|
|
||||||
//LAYOUT
|
//LAYOUT
|
||||||
|
@ -176,10 +176,9 @@ create_layout(Evas_Object *parent, const char *file)
|
||||||
info->animator = animator;
|
info->animator = animator;
|
||||||
evas_object_event_callback_add(layout, EVAS_CALLBACK_DEL, _layout_del_cb, (void *)info);
|
evas_object_event_callback_add(layout, EVAS_CALLBACK_DEL, _layout_del_cb, (void *)info);
|
||||||
|
|
||||||
sprintf(buf, "%d / %ld", 0, view->getTotalFrame());
|
|
||||||
elm_object_part_text_set(layout, "text", buf);
|
|
||||||
|
|
||||||
view->seek(0.0);
|
view->seek(0.0);
|
||||||
|
_update_frame_info(info);
|
||||||
|
|
||||||
return layout;
|
return layout;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -443,7 +443,7 @@ VMatrix renderer::Layer::matrix(int frameNo) const
|
||||||
bool renderer::Layer::visible() const
|
bool renderer::Layer::visible() const
|
||||||
{
|
{
|
||||||
return (frameNo() >= mLayerData->inFrame() &&
|
return (frameNo() >= mLayerData->inFrame() &&
|
||||||
frameNo() < mLayerData->outFrame());
|
frameNo() <= mLayerData->outFrame());
|
||||||
}
|
}
|
||||||
|
|
||||||
void renderer::Layer::preprocess(const VRect &clip)
|
void renderer::Layer::preprocess(const VRect &clip)
|
||||||
|
|
|
@ -539,8 +539,8 @@ public:
|
||||||
{
|
{
|
||||||
return long(frameAtPos(timeInSec / duration()));
|
return long(frameAtPos(timeInSec / duration()));
|
||||||
}
|
}
|
||||||
size_t totalFrame() const { return mEndFrame - mStartFrame; }
|
size_t totalFrame() const { return mEndFrame - mStartFrame + 1; }
|
||||||
long frameDuration() const { return mEndFrame - mStartFrame - 1; }
|
long frameDuration() const { return mEndFrame - mStartFrame; }
|
||||||
float frameRate() const { return mFrameRate; }
|
float frameRate() const { return mFrameRate; }
|
||||||
size_t startFrame() const { return mStartFrame; }
|
size_t startFrame() const { return mStartFrame; }
|
||||||
size_t endFrame() const { return mEndFrame; }
|
size_t endFrame() const { return mEndFrame; }
|
||||||
|
|
|
@ -665,9 +665,9 @@ void LottieParserImpl::parseComposition()
|
||||||
} else if (0 == strcmp(key, "h")) {
|
} else if (0 == strcmp(key, "h")) {
|
||||||
comp->mSize.setHeight(GetInt());
|
comp->mSize.setHeight(GetInt());
|
||||||
} else if (0 == strcmp(key, "ip")) {
|
} else if (0 == strcmp(key, "ip")) {
|
||||||
comp->mStartFrame = GetDouble();
|
comp->mStartFrame = std::lround(GetDouble());
|
||||||
} else if (0 == strcmp(key, "op")) {
|
} else if (0 == strcmp(key, "op")) {
|
||||||
comp->mEndFrame = GetDouble();
|
comp->mEndFrame = std::lround(GetDouble());
|
||||||
} else if (0 == strcmp(key, "fr")) {
|
} else if (0 == strcmp(key, "fr")) {
|
||||||
comp->mFrameRate = GetDouble();
|
comp->mFrameRate = GetDouble();
|
||||||
} else if (0 == strcmp(key, "assets")) {
|
} else if (0 == strcmp(key, "assets")) {
|
||||||
|
|
Loading…
Reference in a new issue