mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-06-01 09:39:25 +00:00
7b7ccd5dce
Can be enabled/disabled at runtime by toggling the 'media.jxr.enabled' pref (disabled by default). Two additional prefs are provided for testing purposes: 'media.jxr.autoaccept', and 'media.jxr.advertised_mime_type' See comments in all.js for information on what these do. This commit includes the MS OpenTech implementation of the decoder on the browser side with some fixes applied; see the development in Pale Moon GitGub issue #105 or my comments in the source code for more information.
166 lines
3.9 KiB
C++
166 lines
3.9 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "nsMimeTypes.h"
|
|
|
|
#include "Image.h"
|
|
#include "nsRefreshDriver.h"
|
|
#include "mozilla/TimeStamp.h"
|
|
|
|
namespace mozilla {
|
|
namespace image {
|
|
|
|
// Constructor
|
|
ImageResource::ImageResource(ImageURL* aURI) :
|
|
mURI(aURI),
|
|
mInnerWindowId(0),
|
|
mAnimationConsumers(0),
|
|
mAnimationMode(kNormalAnimMode),
|
|
mInitialized(false),
|
|
mAnimating(false),
|
|
mError(false)
|
|
{
|
|
}
|
|
|
|
// Translates a mimetype into a concrete decoder
|
|
Image::eDecoderType
|
|
Image::GetDecoderType(const char *aMimeType)
|
|
{
|
|
// By default we don't know
|
|
eDecoderType rv = eDecoderType_unknown;
|
|
|
|
// PNG
|
|
if (!strcmp(aMimeType, IMAGE_PNG))
|
|
rv = eDecoderType_png;
|
|
else if (!strcmp(aMimeType, IMAGE_X_PNG))
|
|
rv = eDecoderType_png;
|
|
|
|
// GIF
|
|
else if (!strcmp(aMimeType, IMAGE_GIF))
|
|
rv = eDecoderType_gif;
|
|
|
|
|
|
// JPEG
|
|
else if (!strcmp(aMimeType, IMAGE_JPEG))
|
|
rv = eDecoderType_jpeg;
|
|
else if (!strcmp(aMimeType, IMAGE_PJPEG))
|
|
rv = eDecoderType_jpeg;
|
|
else if (!strcmp(aMimeType, IMAGE_JPG))
|
|
rv = eDecoderType_jpeg;
|
|
|
|
#ifdef MOZ_JXR
|
|
// JXR (JPEG XR)
|
|
else if (
|
|
!strcmp(aMimeType, IMAGE_JXR) || !strcmp(aMimeType, IMAGE_MS_PHOTO)
|
|
) {
|
|
if (gfxPrefs::MediaJXREnabled()) {
|
|
rv = eDecoderType_jxr;
|
|
}
|
|
}
|
|
#endif
|
|
|
|
// WEBP
|
|
else if (!strcmp(aMimeType, IMAGE_WEBP))
|
|
rv = eDecoderType_webp;
|
|
|
|
// BMP
|
|
else if (!strcmp(aMimeType, IMAGE_BMP))
|
|
rv = eDecoderType_bmp;
|
|
else if (!strcmp(aMimeType, IMAGE_BMP_MS))
|
|
rv = eDecoderType_bmp;
|
|
|
|
|
|
// ICO
|
|
else if (!strcmp(aMimeType, IMAGE_ICO))
|
|
rv = eDecoderType_ico;
|
|
else if (!strcmp(aMimeType, IMAGE_ICO_MS))
|
|
rv = eDecoderType_ico;
|
|
|
|
// Icon
|
|
else if (!strcmp(aMimeType, IMAGE_ICON_MS))
|
|
rv = eDecoderType_icon;
|
|
|
|
return rv;
|
|
}
|
|
|
|
void
|
|
ImageResource::IncrementAnimationConsumers()
|
|
{
|
|
MOZ_ASSERT(NS_IsMainThread(), "Main thread only to encourage serialization "
|
|
"with DecrementAnimationConsumers");
|
|
mAnimationConsumers++;
|
|
}
|
|
|
|
void
|
|
ImageResource::DecrementAnimationConsumers()
|
|
{
|
|
MOZ_ASSERT(NS_IsMainThread(), "Main thread only to encourage serialization "
|
|
"with IncrementAnimationConsumers");
|
|
MOZ_ASSERT(mAnimationConsumers >= 1, "Invalid no. of animation consumers!");
|
|
mAnimationConsumers--;
|
|
}
|
|
|
|
nsresult
|
|
ImageResource::GetAnimationModeInternal(uint16_t* aAnimationMode)
|
|
{
|
|
if (mError)
|
|
return NS_ERROR_FAILURE;
|
|
|
|
NS_ENSURE_ARG_POINTER(aAnimationMode);
|
|
|
|
*aAnimationMode = mAnimationMode;
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
ImageResource::SetAnimationModeInternal(uint16_t aAnimationMode)
|
|
{
|
|
if (mError)
|
|
return NS_ERROR_FAILURE;
|
|
|
|
NS_ASSERTION(aAnimationMode == kNormalAnimMode ||
|
|
aAnimationMode == kDontAnimMode ||
|
|
aAnimationMode == kLoopOnceAnimMode,
|
|
"Wrong Animation Mode is being set!");
|
|
|
|
mAnimationMode = aAnimationMode;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
bool
|
|
ImageResource::HadRecentRefresh(const TimeStamp& aTime)
|
|
{
|
|
// Our threshold for "recent" is 1/2 of the default refresh-driver interval.
|
|
// This ensures that we allow for frame rates at least as fast as the
|
|
// refresh driver's default rate.
|
|
static TimeDuration recentThreshold =
|
|
TimeDuration::FromMilliseconds(nsRefreshDriver::DefaultInterval() / 2.0);
|
|
|
|
if (!mLastRefreshTime.IsNull() &&
|
|
aTime - mLastRefreshTime < recentThreshold) {
|
|
return true;
|
|
}
|
|
|
|
// else, we can proceed with a refresh.
|
|
// But first, update our last refresh time:
|
|
mLastRefreshTime = aTime;
|
|
return false;
|
|
}
|
|
|
|
void
|
|
ImageResource::EvaluateAnimation()
|
|
{
|
|
if (!mAnimating && ShouldAnimate()) {
|
|
nsresult rv = StartAnimation();
|
|
mAnimating = NS_SUCCEEDED(rv);
|
|
} else if (mAnimating && !ShouldAnimate()) {
|
|
StopAnimation();
|
|
}
|
|
}
|
|
|
|
} // namespace image
|
|
} // namespace mozilla
|