// initialize jwplayer var playerInstance = jwplayer('player');// player dom elements var playerContainerEl = document.querySelector('.player-container');// returns video player position from top of document function getElementOffsetTop(el) { var boundingClientRect = el.getBoundingClientRect(); var bodyEl = document.body; var docEl = document.documentElement; var scrollTop = window.pageYOffset || docEl.scrollTop || bodyEl.scrollTop; var clientTop = docEl.clientTop || bodyEl.clientTop || 0; return Math.round(boundingClientRect.top + scrollTop - clientTop); }// returns the current y scroll position function getScrollTop() { var docEl = document.documentElement; return (window.pageYOffset || docEl.scrollTop) - (docEl.clientTop || 0); }// configure jwplayer instance playerInstance.setup({ autostart: true, playlist: 'https://cdn.jwplayer.com/v2/playlists/mYdavspX', primary: 'html5', setFullscreen: true, width: '100%' });// when jwplayer instance is ready playerInstance.on('ready', function() { var config = playerInstance.getConfig(); var utils = playerInstance.utils; // get height of player element var playerHeight = config.containerHeight; // flag determining whether close has been clicked var closed = true; // CHANGED // flag determing whether player is playing var playing = false; // ADDED // eventhandler for when close button is being pressed document.getElementsByClassName('icon-close')[0].addEventListener('click', () => { closed = true; onScrollViewHandler(); }); playerInstance.on('play', function() { closed = false; playing = true; // ADDED }).on('pause', function () { playing = false; // ADDED }).on('adPlay', function() { closed = false; // ADDED playing = true; // ADDED }).on('adPause', function() { playing = false; // ADDED });// get player element position from top of document var playerOffsetTop = getElementOffsetTop(playerContainerEl);// set player container to match height of actual video element playerContainerEl.style.height = playerHeight + 'px';// below we handle window scroll event without killing performance function onScrollViewHandler() { var minimized = getScrollTop() >= playerOffsetTop;if (closed && minimized) { minimized = false; jwplayer().pause(); playing = false; // ADDED } else if (!minimized && !playing) { closed = true; // ADDED } utils.toggleClass(playerContainerEl, 'player-minimize', minimized); // update the player's size so the controls are adjusted playerInstance.resize(); }// namespace for whether or not we are waiting for setTimeout() to finish var isScrollTimeout = false;// window onscroll event handler window.onscroll = function() { // skip if we're waiting on a scroll update timeout to finish if (isScrollTimeout) return; // flag that a new timeout will begin isScrollTimeout = true; // otherwise, call scroll event view handler onScrollViewHandler(); // set new timeout setTimeout(function() { // reset timeout flag to false (no longer waiting) isScrollTimeout = false; }, 80); };});

During the E3 Coliseum Panel, Infinity Ward provided us with some additional details on the characters of the Call of Duty: Modern Warfare campaign.

The story of Call of Duty: Modern Warfare will be playable from two sides; one half with be from the Tier 1 Operators side, the other will be from the side of playing with Rebel Fighters.

Captain Price

Captain Price returns, but is played by a new voice actor. Captain Price serves as the Commander of your Tier 1 unit that you will play alongside during half of the Call of Duty: Modern Warfare campaign.

Kyle Gerrick

Kyle Gerrick is a former British Army Officer who joins the fight to fight side by side with Captain Price on the war going on around the world. He works in the counter terror division.

Alex

Alex is the character you play as for a second half of the campaign. Alex is a CIA embed sent to a country in the Middle East to fight alongside Rebel Fighters in the region.

Farrah

Farrah is the Commander of the Rebel Fighters and you will play alongside her during a half of the campaign, when you get to see the perspective of the rebel fighters in Modern Warfare. Farrah was not going to be in the Army but the war came to her region, and she had to take a stand.

The E3 Panel also gave fans first two teaser images of the game’s Multiplayer mode, which you can checkout here.

comments below