Skip to content

Commit

Permalink
Add tentative seamless loop mode if only one video in playlist
Browse files Browse the repository at this point in the history
  • Loading branch information
glouel committed Feb 3, 2020
1 parent 52157b2 commit be24fb1
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 10 deletions.
8 changes: 4 additions & 4 deletions Aerial.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -1367,15 +1367,15 @@
CODE_SIGN_IDENTITY = "Developer ID Application: Guillaume Louel (3L54M5L5KK)";
CODE_SIGN_STYLE = Manual;
COMBINE_HIDPI_IMAGES = YES;
CURRENT_PROJECT_VERSION = 1.7.0;
CURRENT_PROJECT_VERSION = 1.7.1beta1;
DEFINES_MODULE = YES;
DEVELOPMENT_TEAM = 3L54M5L5KK;
ENABLE_HARDENED_RUNTIME = YES;
INFOPLIST_FILE = "$(SRCROOT)/Resources/Info.plist";
INSTALL_PATH = "$(HOME)/Library/Screen Savers";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks";
MACOSX_DEPLOYMENT_TARGET = 10.9;
MARKETING_VERSION = 1.7.0;
MARKETING_VERSION = 1.7.1beta1;
PRODUCT_BUNDLE_IDENTIFIER = com.johncoates.Aerial;
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE_SPECIFIER = "";
Expand All @@ -1396,15 +1396,15 @@
CODE_SIGN_IDENTITY = "Developer ID Application: Guillaume Louel (3L54M5L5KK)";
CODE_SIGN_STYLE = Manual;
COMBINE_HIDPI_IMAGES = YES;
CURRENT_PROJECT_VERSION = 1.7.0;
CURRENT_PROJECT_VERSION = 1.7.1beta1;
DEFINES_MODULE = YES;
DEVELOPMENT_TEAM = 3L54M5L5KK;
ENABLE_HARDENED_RUNTIME = YES;
INFOPLIST_FILE = "$(SRCROOT)/Resources/Info.plist";
INSTALL_PATH = "$(HOME)/Library/Screen Savers";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks";
MACOSX_DEPLOYMENT_TARGET = 10.9;
MARKETING_VERSION = 1.7.0;
MARKETING_VERSION = 1.7.1beta1;
OTHER_CODE_SIGN_FLAGS = "--timestamp";
PRODUCT_BUNDLE_IDENTIFIER = com.johncoates.Aerial;
PRODUCT_NAME = "$(TARGET_NAME)";
Expand Down
12 changes: 9 additions & 3 deletions Aerial/Source/Models/ManifestLoader.swift
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,7 @@ class ManifestLoader {

// MARK: - Playlist generation
func generatePlaylist(isRestricted: Bool, restrictedTo: String) {
print("genplaylist")
// Start fresh
playlist = [AerialVideo]()
playlistIsRestricted = isRestricted
Expand Down Expand Up @@ -206,22 +207,27 @@ class ManifestLoader {
}
}

func randomVideo(excluding: [AerialVideo]) -> AerialVideo? {
func randomVideo(excluding: [AerialVideo]) -> (AerialVideo?, Bool) {
var shouldLoop = false
let timeManagement = TimeManagement.sharedInstance
let (shouldRestrictByDayNight, restrictTo) = timeManagement.shouldRestrictPlaybackToDayNightVideo()

// We may need to regenerate a playlist!
if playlist.isEmpty || restrictTo != playlistRestrictedTo || shouldRestrictByDayNight != playlistIsRestricted {
generatePlaylist(isRestricted: shouldRestrictByDayNight, restrictedTo: restrictTo)
if playlist.count == 1 {
debugLog("playlist only has one element, looping!")
shouldLoop = true
}
}

// If not pluck one from current playlist and return that
if !playlist.isEmpty {
lastPluckedFromPlaylist = playlist.removeFirst()
return lastPluckedFromPlaylist
return (lastPluckedFromPlaylist, shouldLoop)
} else {
// If we don't have any playlist, something's got awfully wrong so deal with that!
return findBestEffortVideo()
return (findBestEffortVideo(), shouldLoop)
}
}

Expand Down
13 changes: 11 additions & 2 deletions Aerial/Source/Views/AerialView+Player.swift
Original file line number Diff line number Diff line change
Expand Up @@ -88,8 +88,17 @@ extension AerialView {
@objc func playerItemDidReachEnd(_ aNotification: Notification) {
debugLog("\(self.description) played did reach end")
debugLog("\(self.description) notification: \(aNotification)")
playNextVideo()
debugLog("\(self.description) playing next video for player \(String(describing: player))")

if shouldLoop {
debugLog("Rewinding video!")
if let playerItem = aNotification.object as? AVPlayerItem {
playerItem.seek(to: CMTime.zero, completionHandler: nil)
}
} else {
playNextVideo()
debugLog("\(self.description) playing next video for player \(String(describing: player))")
}

}

// Video fade-in/out
Expand Down
9 changes: 8 additions & 1 deletion Aerial/Source/Views/AerialView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,9 @@ final class AerialView: ScreenSaverView, CAAnimationDelegate {
// We use this for tentative Catalina bug workaround
var originalWidth, originalHeight: CGFloat

// Tentative improvement when only one video in playlist
var shouldLoop = false

static var shouldFade: Bool {
return (PrefsVideos.fadeMode != .disabled)
}
Expand Down Expand Up @@ -365,6 +368,7 @@ final class AerialView: ScreenSaverView, CAAnimationDelegate {

// MARK: - playNextVideo()
func playNextVideo() {
print("playnext")
let notificationCenter = NotificationCenter.default
// Clear everything
layerManager.clearLayerAnimations(player: self.player!)
Expand Down Expand Up @@ -406,7 +410,10 @@ final class AerialView: ScreenSaverView, CAAnimationDelegate {
(player.currentItem as? AerialPlayerItem)?.video
}

let randomVideo = ManifestLoader.instance.randomVideo(excluding: currentVideos)
let (randomVideo, pshouldLoop) = ManifestLoader.instance.randomVideo(excluding: currentVideos)

// If we only have one video in the playlist, we can rewind it for seamless transitions
self.shouldLoop = pshouldLoop

guard let video = randomVideo else {
errorLog("\(self.description) Error grabbing random video!")
Expand Down

0 comments on commit be24fb1

Please sign in to comment.