resized view controllers

This commit is contained in:
Okechi 2016-03-20 22:55:19 -04:00
parent 994e033bfd
commit b6378b35e7
4 changed files with 879 additions and 262 deletions

View File

@ -38,7 +38,7 @@ class CurrentlyPlayingViewController: UIViewController, PartyServiceManagerDeleg
self.audioPlayer.volume = sender.value
}
@IBAction func playPauseFav(sender: UIButton){
if (self.party.role == PeerType.Host_Creator){
if (self.party.role == PeerType.Host_Creator || self.party.role == PeerType.Guest_Creator){
if(playing == true){
for peer in self.party.session.connectedPeers {
var dictionary: [String: String] = ["sender": self.party.myPeerID.displayName, "instruction": "pause_stream"]
@ -76,7 +76,7 @@ class CurrentlyPlayingViewController: UIViewController, PartyServiceManagerDeleg
// Do any additional setup after loading the view.
self.progressBar.setProgress(0, animated: true)
if(self.party.role == PeerType.Host_Creator){
if(self.party.role == PeerType.Host_Creator || self.party.role == PeerType.Guest_Creator){
self.audioPlayer = AVPlayer(URL: self.party.currentSong.valueForProperty(MPMediaItemPropertyAssetURL) as! NSURL)
self.songImg.image = self.party.currentSong.valueForProperty(MPMediaItemPropertyArtwork).imageWithSize(songImg.frame.size)
@ -90,7 +90,16 @@ class CurrentlyPlayingViewController: UIViewController, PartyServiceManagerDeleg
}
self.audioPlayer.play()
self.timer = NSTimer.scheduledTimerWithTimeInterval(1, target: self, selector: Selector("updateLabels"), userInfo: nil, repeats: true)
}else if (self.party.role == PeerType.Guest_Invited){
//sets the next host of the party once the party starts
self.party.chooseNextHost()
print(self.party.currentHost)
//used to notify for end of song and initiate next host loop
//NSNotificationCenter.defaultCenter().addObserver(self, selector: "songDidEnd:", name: "AVPlayerItemDidPlayToEndTimeNotification", object: nil)
}else if (self.party.role == PeerType.Guest_Invited || self.party.role == PeerType.Host_Invited){
self.songImg.image = self.party.currentSongIMG
self.titleLabel.text = (self.party.currentSongTitle)
@ -102,21 +111,28 @@ class CurrentlyPlayingViewController: UIViewController, PartyServiceManagerDeleg
}
//sets the next host of the party once the party starts
if(self.party.role == PeerType.Guest_Creator || self.party.role == PeerType.Host_Creator){
self.party.chooseNextHost()
print(self.party.currentHost)
NSNotificationCenter.defaultCenter().addObserver(self, selector: "songDidEnd:", name: "gotDisplayID", object: nil)
}
}
func songDidEnd(notification: NSNotification){
self.performSegueWithIdentifier("NextUpSegue", sender: nil)
if(self.party.role == PeerType.Host_Creator){
self.party.role == PeerType.Host_Invited
}else if (self.party.role == PeerType.Guest_Creator){
self.party.role == PeerType.Guest_Invited
}
for peer in self.party.connectedPeers() as! [MCPeerID]{
if (peer.displayName == self.party.currentHost){
var dictionary: [String: AnyObject] = ["sender": self.party.myPeerID, "instruction": "start_picking_a_song"]
self.party.sendInstruction(dictionary, toPeer: peer)
}else{
var dictionary: [String: AnyObject] = ["sender": self.party.myPeerID, "instruction": "wait_in_nextUp_Scene"]
self.party.sendInstruction(dictionary, toPeer: peer)
}
}
self.performSegueWithIdentifier("NextUpSegue", sender: self)
}
func timeFormat(value: Float) -> String{
@ -195,6 +211,18 @@ class CurrentlyPlayingViewController: UIViewController, PartyServiceManagerDeleg
if segue.identifier == "NextUpSegue" {
let vc: NextUpViewController = (segue.destinationViewController as? NextUpViewController)!
vc.setData(self.party, user: self.usr, friends: self.frnds, request: self.requestData)
}
if segue.identifier == "NextSongSelectionSegue" {
let vc: SongSelectionViewController = (segue.destinationViewController as? SongSelectionViewController)!
vc.setData(self.party, user: self.usr, friends: self.frnds, request: self.requestData)
}
}
@ -238,7 +266,7 @@ extension CurrentlyPlayingViewController: PartyServiceManagerDelegate {
}else if(instruction == "want_to_be_host"){
let alert = UIAlertController(title: "Host Request", message: "Would you like to be the next host for the party and pick a song?", preferredStyle: .Alert)
let alert = UIAlertController(title: "Hosting Request", message: "Would you like to be the next host for the party and pick a song?", preferredStyle: .Alert)
alert.addAction(UIAlertAction(title: "Accept", style: .Default, handler:{
(action: UIAlertAction!) -> Void in
@ -255,6 +283,17 @@ extension CurrentlyPlayingViewController: PartyServiceManagerDelegate {
}))
self.presentViewController(alert, animated: true, completion: nil)
}else if(instruction == "start_picking_a_song"){
if(self.party.role == PeerType.Host_Invited){
self.party.role == PeerType.Host_Creator
}
if(self.party.role == PeerType.Guest_Invited){
self.party.role == PeerType.Guest_Creator
}
self.performSegueWithIdentifier("NextSongSelectionSegue", sender: self)
}else if(instruction == "wait_in_nextUp_Scene"){
self.performSegueWithIdentifier("NextUpSegue", sender: self)
}
}

File diff suppressed because it is too large Load Diff

View File

@ -7,8 +7,9 @@
//
import UIKit
import MultipeerConnectivity
class NextUpViewController: UIViewController {
class NextUpViewController: UIViewController, PartyServiceManagerDelegate {
var party: PartyServiceManager!
var usr: [UserParseData] = []
var frnds: [FriendData] = []
@ -17,6 +18,7 @@ class NextUpViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
self.party.delegate = self
self.userImages.layer.cornerRadius = self.userImages.frame.size.width/2
self.userImages.clipsToBounds = true
// Do any additional setup after loading the view.
@ -35,14 +37,55 @@ class NextUpViewController: UIViewController {
self.requestData = request
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
if(segue.identifier == "NextSongSegue"){
let vc: CurrentlyPlayingViewController = (segue.destinationViewController as? CurrentlyPlayingViewController)!
vc.setData(self.party, user: self.usr, friends: self.frnds, request: self.requestData)
}
*/
}
}
extension NextUpViewController: PartyServiceManagerDelegate {
func foundPeer() {
}
func lostPeer() {
}
func invitationWasRecieved(peerID: MCPeerID, invitationHandler: ((Bool, MCSession!) -> Void)!) {
}
func connectedWithPeer(peerID: MCPeerID) {
}
func didRecieveInstruction(dictionary: Dictionary<String, AnyObject>){
let (instruction, fromPeer) = self.party.decodeInstruction(dictionary)
if self.party.disconnectedPeersDictionary[fromPeer.displayName] != nil {
var dictionary: [String: String] = ["sender": self.party.myPeerID.displayName, "instruction": "disconnect"]
self.party.sendInstruction(dictionary, toPeer: fromPeer)
}else{
if (instruction == "start"){
self.performSegueWithIdentifier("NextSongSegue", sender: self)
}
}
}
}

View File

@ -8,6 +8,7 @@
import UIKit
import MediaPlayer
import MultipeerConnectivity
class SongSelectionViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
var party: PartyServiceManager!
@ -167,7 +168,12 @@ class SongSelectionViewController: UIViewController, UITableViewDelegate, UITabl
var songs = songsQuery.items
var rowItem: MPMediaItem = songs[indexPath.row - 1] as! MPMediaItem
self.party.setSong(rowItem)
self.performSegueWithIdentifier("LoadingPartySegue", sender: nil)
if(self.party.role == PeerType.Host_Creator){
self.performSegueWithIdentifier("LoadingPartySegue", sender: self)
}else{
self.performSegueWithIdentifier("NextSongCurrentlyPlayingSegue", sender: self)
}
}
}
@ -287,6 +293,35 @@ class SongSelectionViewController: UIViewController, UITableViewDelegate, UITabl
}
}
if(segue.identifier == "NextSongCurrentlyPlayingSegue"){
let vc: CurrentlyPlayingViewController = (segue.destinationViewController as? CurrentlyPlayingViewController)!
vc.setData(self.party, user: self.usr, friends: self.frnds, request: self.requestData)
//sends music info incuding, title, artist, album, and image
var dictionary: [String: AnyObject] = ["sender": self.party.myPeerID.displayName, "instruction": "set_up_song", "songTitle": (self.party.currentSong.valueForProperty(MPMediaItemPropertyTitle) as? String!)!, "songArtistAndAlbum": (self.party.currentSong.valueForProperty(MPMediaItemPropertyArtist) as? String!)! + " - " + (self.party.currentSong.valueForProperty(MPMediaItemPropertyAlbumTitle) as? String!)!, "songImage": UIImagePNGRepresentation(self.party.currentSong.valueForProperty(MPMediaItemPropertyArtwork).imageWithSize(CGSize(width: 320, height: 320)) )]
for peer in self.party.connectedPeers() as! [MCPeerID] {
self.party.sendInstruction(dictionary, toPeer: peer)
//open stream with peer
let stream = self.party.outputStreamForPeer(peer)
self.party.outputStreamers[peer.displayName] = TDAudioOutputStreamer(outputStream: stream)
self.party.outputStreamers[peer.displayName]!.streamAudioFromURL((self.party.currentSong.valueForProperty(MPMediaItemPropertyAssetURL) as! NSURL))
}
dictionary = ["sender": self.party.myPeerID.displayName, "instruction": "start"]
for peer in self.party.connectedPeers() as! [MCPeerID] {
self.party.sendInstruction(dictionary, toPeer: peer)
}
}
}