gecko-dev/dom/media/MediaTrack.h

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

81 строка
2.6 KiB
C
Исходник Обычный вид История

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set ts=2 sw=2 et tw=78: */
/* 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/. */
#ifndef mozilla_dom_MediaTrack_h
#define mozilla_dom_MediaTrack_h
#include "mozilla/DOMEventTargetHelper.h"
namespace mozilla {
namespace dom {
class MediaTrackList;
class VideoTrack;
class AudioTrack;
/**
* Base class of AudioTrack and VideoTrack. The AudioTrack and VideoTrack
* objects represent specific tracks of a media resource. Each track has aspects
* of an identifier, category, label, and language, even if a track is removed
* from its corresponding track list, those aspects do not change.
*
* When fetching the media resource, an audio/video track is created if the
* media resource is found to have an audio/video track. When the UA has learned
* that an audio/video track has ended, this audio/video track will be removed
* from its corresponding track list.
*
* Although AudioTrack and VideoTrack are not EventTargets, TextTrack is, and
* TextTrack inherits from MediaTrack as well (or is going to).
*/
class MediaTrack : public DOMEventTargetHelper {
public:
MediaTrack(nsIGlobalObject* aOwnerGlobal, const nsAString& aId,
const nsAString& aKind, const nsAString& aLabel,
const nsAString& aLanguage);
NS_DECL_ISUPPORTS_INHERITED
Backed out 7 changesets (bug 1454998) for build bustages at MediaTrackGraph.h on a CLOSED TREE. Backed out changeset 80417bdfa721 (bug 1454998) Backed out changeset 8ff03f2f4ca2 (bug 1454998) Backed out changeset ae6056b748d1 (bug 1454998) Backed out changeset ab721cb2066b (bug 1454998) Backed out changeset d0e8d413cd1c (bug 1454998) Backed out changeset 3ce4dc7e9ae2 (bug 1454998) Backed out changeset 6105a4176729 (bug 1454998) --HG-- rename : dom/media/AudioCaptureTrack.cpp => dom/media/AudioCaptureStream.cpp rename : dom/media/AudioCaptureTrack.h => dom/media/AudioCaptureStream.h rename : dom/media/MediaTrackGraph.cpp => dom/media/MediaStreamGraph.cpp rename : dom/media/MediaTrackGraph.h => dom/media/MediaStreamGraph.h rename : dom/media/MediaTrackGraphImpl.h => dom/media/MediaStreamGraphImpl.h rename : dom/media/MediaTrackListener.cpp => dom/media/MediaStreamListener.cpp rename : dom/media/MediaTrackListener.h => dom/media/MediaStreamListener.h rename : dom/media/ForwardedInputTrack.cpp => dom/media/TrackUnionStream.cpp rename : dom/media/ForwardedInputTrack.h => dom/media/TrackUnionStream.h rename : dom/media/webaudio/AudioNodeExternalInputTrack.cpp => dom/media/webaudio/AudioNodeExternalInputStream.cpp rename : dom/media/webaudio/AudioNodeExternalInputTrack.h => dom/media/webaudio/AudioNodeExternalInputStream.h rename : dom/media/webaudio/AudioNodeTrack.cpp => dom/media/webaudio/AudioNodeStream.cpp rename : dom/media/webaudio/AudioNodeTrack.h => dom/media/webaudio/AudioNodeStream.h
2019-10-02 11:46:23 +03:00
NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED(MediaTrack, DOMEventTargetHelper)
enum {
DEFAULT = 0,
FIRE_NO_EVENTS = 1 << 0,
};
// The default behavior of enabling an audio track or selecting a video track
// fires a change event and notifies its media resource about the changes.
// It should not fire any events when fetching media resource.
virtual void SetEnabledInternal(bool aEnabled, int aFlags) = 0;
virtual AudioTrack* AsAudioTrack() { return nullptr; }
virtual VideoTrack* AsVideoTrack() { return nullptr; }
const nsString& GetId() const { return mId; }
// WebIDL
void GetId(nsAString& aId) const { aId = mId; }
void GetKind(nsAString& aKind) const { aKind = mKind; }
void GetLabel(nsAString& aLabel) const { aLabel = mLabel; }
void GetLanguage(nsAString& aLanguage) const { aLanguage = mLanguage; }
friend class MediaTrackList;
protected:
virtual ~MediaTrack();
void SetTrackList(MediaTrackList* aList);
Bug 1207245 - part 6 - rename nsRefPtr<T> to RefPtr<T>; r=ehsan; a=Tomcat The bulk of this commit was generated with a script, executed at the top level of a typical source code checkout. The only non-machine-generated part was modifying MFBT's moz.build to reflect the new naming. CLOSED TREE makes big refactorings like this a piece of cake. # The main substitution. find . -name '*.cpp' -o -name '*.cc' -o -name '*.h' -o -name '*.mm' -o -name '*.idl'| \ xargs perl -p -i -e ' s/nsRefPtr\.h/RefPtr\.h/g; # handle includes s/nsRefPtr ?</RefPtr</g; # handle declarations and variables ' # Handle a special friend declaration in gfx/layers/AtomicRefCountedWithFinalize.h. perl -p -i -e 's/::nsRefPtr;/::RefPtr;/' gfx/layers/AtomicRefCountedWithFinalize.h # Handle nsRefPtr.h itself, a couple places that define constructors # from nsRefPtr, and code generators specially. We do this here, rather # than indiscriminantly s/nsRefPtr/RefPtr/, because that would rename # things like nsRefPtrHashtable. perl -p -i -e 's/nsRefPtr/RefPtr/g' \ mfbt/nsRefPtr.h \ xpcom/glue/nsCOMPtr.h \ xpcom/base/OwningNonNull.h \ ipc/ipdl/ipdl/lower.py \ ipc/ipdl/ipdl/builtin.py \ dom/bindings/Codegen.py \ python/lldbutils/lldbutils/utils.py # In our indiscriminate substitution above, we renamed # nsRefPtrGetterAddRefs, the class behind getter_AddRefs. Fix that up. find . -name '*.cpp' -o -name '*.h' -o -name '*.idl' | \ xargs perl -p -i -e 's/nsRefPtrGetterAddRefs/RefPtrGetterAddRefs/g' if [ -d .git ]; then git mv mfbt/nsRefPtr.h mfbt/RefPtr.h else hg mv mfbt/nsRefPtr.h mfbt/RefPtr.h fi --HG-- rename : mfbt/nsRefPtr.h => mfbt/RefPtr.h
2015-10-18 08:24:48 +03:00
RefPtr<MediaTrackList> mList;
nsString mId;
nsString mKind;
nsString mLabel;
nsString mLanguage;
};
} // namespace dom
} // namespace mozilla
#endif // mozilla_dom_MediaTrack_h