Updated PlayTo profiles and recognition

This commit is contained in:
7illusions 2014-03-15 17:11:10 +01:00
parent d55af4f529
commit db3b106fe0
5 changed files with 216 additions and 8 deletions

View File

@ -33,6 +33,14 @@ namespace MediaBrowser.Controller.Dlna
/// <value>The name of the model.</value> /// <value>The name of the model.</value>
public string ModelName { get; set; } public string ModelName { get; set; }
/// <summary>
/// Gets or sets the manufacturer.
/// </summary>
/// <value>
/// The manufacturer.
/// </value>
public string Manufacturer { get; set; }
/// <summary> /// <summary>
/// Gets or sets the transcoding profiles. /// Gets or sets the transcoding profiles.
/// </summary> /// </summary>

View File

@ -22,7 +22,8 @@ namespace MediaBrowser.Controller.Dlna
/// <param name="friendlyName">Name of the friendly.</param> /// <param name="friendlyName">Name of the friendly.</param>
/// <param name="modelName">Name of the model.</param> /// <param name="modelName">Name of the model.</param>
/// <param name="modelNumber">The model number.</param> /// <param name="modelNumber">The model number.</param>
/// <returns>DlnaProfile.</returns> /// <param name="manufacturer">The manufacturer.</param>
DeviceProfile GetProfile(string friendlyName, string modelName, string modelNumber); /// <returns>DlnaProfile.</</returns>
DeviceProfile GetProfile(string friendlyName, string modelName, string modelNumber, string manufacturer);
} }
} }

View File

@ -25,6 +25,8 @@ namespace MediaBrowser.Dlna
{ {
var list = new List<DeviceProfile>(); var list = new List<DeviceProfile>();
#region Samsung
list.Add(new DeviceProfile list.Add(new DeviceProfile
{ {
Name = "Samsung TV (B Series)", Name = "Samsung TV (B Series)",
@ -169,6 +171,10 @@ namespace MediaBrowser.Dlna
} }
}); });
#endregion
#region Xbox
list.Add(new DeviceProfile list.Add(new DeviceProfile
{ {
Name = "Xbox 360", Name = "Xbox 360",
@ -198,7 +204,7 @@ namespace MediaBrowser.Dlna
new DirectPlayProfile new DirectPlayProfile
{ {
Containers = new[]{"avi"}, Containers = new[]{"avi"},
MimeType = "x-msvideo", MimeType = "avi",
Type = DlnaProfileType.Video Type = DlnaProfileType.Video
} }
} }
@ -240,6 +246,10 @@ namespace MediaBrowser.Dlna
} }
}); });
#endregion
#region Sony
list.Add(new DeviceProfile list.Add(new DeviceProfile
{ {
Name = "Sony Bravia (2012)", Name = "Sony Bravia (2012)",
@ -276,6 +286,173 @@ namespace MediaBrowser.Dlna
} }
}); });
list.Add(new DeviceProfile
{
Name = "Sony Bravia (2013)",
ClientType = "DLNA",
FriendlyName = @"BRAVIA (KDL-\d{2}W[689]\d{2}A.*)|(KD-\d{2}X9\d{3}A.*)",
TranscodingProfiles = new[]
{
new TranscodingProfile
{
Container = "mp3",
Type = DlnaProfileType.Audio
},
new TranscodingProfile
{
Container = "ts",
Type = DlnaProfileType.Video,
MimeType = "mpeg"
}
},
DirectPlayProfiles = new[]
{
new DirectPlayProfile
{
Containers = new[]{"mp3"},
Type = DlnaProfileType.Audio
},
new DirectPlayProfile
{
Containers = new[]{"wma"},
Type = DlnaProfileType.Audio,
MimeType = "x-ms-wma"
},
new DirectPlayProfile
{
Containers = new[]{"avi"},
Type = DlnaProfileType.Video,
MimeType = "avi"
},
new DirectPlayProfile
{
Containers = new[]{"mp4"},
Type = DlnaProfileType.Video,
MimeType = "mp4"
}
}
});
#endregion
#region Panasonic
list.Add(new DeviceProfile
{
//Panasonic Viera (2011|2012) Without AVI Support
Name = "Panasonic Viera E/S/ST/VT (2011)",
ClientType = "DLNA",
FriendlyName = @"(VIERA (E|S)T?(3|5)0?.*)|(VIERA VT30.*)",
Manufacturer = "Panasonic",
TranscodingProfiles = new[]
{
new TranscodingProfile
{
Container = "mp3",
Type = DlnaProfileType.Audio
},
new TranscodingProfile
{
Container = "ts",
Type = DlnaProfileType.Video
}
},
DirectPlayProfiles = new[]
{
new DirectPlayProfile
{
Containers = new[]{"mp3"},
Type = DlnaProfileType.Audio
},
new DirectPlayProfile
{
Containers = new[]{"mkv"},
Type = DlnaProfileType.Video
}
}
});
list.Add(new DeviceProfile
{
//Panasonic Viera (2011|2012) With AVI Support
Name = "Panasonic Viera G/GT/DT/UT/VT (2011/2012)",
ClientType = "DLNA",
FriendlyName = @"(VIERA (G|D|U)T?(3|5)0?.*)|(VIERA VT50.*)",
Manufacturer = "Panasonic",
TranscodingProfiles = new[]
{
new TranscodingProfile
{
Container = "mp3",
Type = DlnaProfileType.Audio
},
new TranscodingProfile
{
Container = "ts",
Type = DlnaProfileType.Video
}
},
DirectPlayProfiles = new[]
{
new DirectPlayProfile
{
Containers = new[]{"mp3"},
Type = DlnaProfileType.Audio
},
new DirectPlayProfile
{
Containers = new[]{"mkv"},
Type = DlnaProfileType.Video
},
new DirectPlayProfile
{
Containers = new[]{"avi"},
Type = DlnaProfileType.Video ,
MimeType="divx"
}
}
});
#endregion
//WDTV does not need any transcoding of the formats we support statically
list.Add(new DeviceProfile
{
Name = "Philips (2010-)",
FriendlyName = ".*PHILIPS.*",
ClientType = "DLNA",
ModelName = "WD TV HD Live",
DirectPlayProfiles = new[]
{
new DirectPlayProfile
{
Containers = new[]{"mp3", "wma"},
Type = DlnaProfileType.Audio
},
new DirectPlayProfile
{
Containers = new[]{"avi"},
Type = DlnaProfileType.Video,
MimeType = "avi"
},
new DirectPlayProfile
{
Containers = new[]{"mkv"},
Type = DlnaProfileType.Video,
MimeType = "x-matroska"
}
}
});
//WDTV does not need any transcoding of the formats we support statically //WDTV does not need any transcoding of the formats we support statically
list.Add(new DeviceProfile list.Add(new DeviceProfile
{ {
@ -322,6 +499,23 @@ namespace MediaBrowser.Dlna
} }
}); });
list.Add(new DeviceProfile
{
Name = "Denon AVR",
FriendlyName = @"Denon:\[AVR:.*",
Manufacturer = "Denon",
ClientType = "DLNA",
DirectPlayProfiles = new[]
{
new DirectPlayProfile
{
Containers = new[]{"mp3", "flac", "m4a", "wma"},
Type = DlnaProfileType.Audio
},
}
});
foreach (var item in list) foreach (var item in list)
{ {
//_xmlSerializer.SerializeToFile(item, "d:\\" + _fileSystem.GetValidFilename(item.Name)); //_xmlSerializer.SerializeToFile(item, "d:\\" + _fileSystem.GetValidFilename(item.Name));
@ -365,7 +559,7 @@ namespace MediaBrowser.Dlna
}; };
} }
public DeviceProfile GetProfile(string friendlyName, string modelName, string modelNumber) public DeviceProfile GetProfile(string friendlyName, string modelName, string modelNumber, string manufacturer)
{ {
foreach (var profile in GetProfiles()) foreach (var profile in GetProfiles())
{ {
@ -387,6 +581,12 @@ namespace MediaBrowser.Dlna
continue; continue;
} }
if (!string.IsNullOrEmpty(profile.Manufacturer))
{
if (!Regex.IsMatch(manufacturer, profile.Manufacturer))
continue;
}
return profile; return profile;
} }

View File

@ -386,7 +386,7 @@ namespace MediaBrowser.Dlna.PlayTo
var deviceInfo = _device.Properties; var deviceInfo = _device.Properties;
var playlistItem = PlaylistItem.Create(item, _dlnaManager.GetProfile(deviceInfo.Name, deviceInfo.ModelName, deviceInfo.ModelNumber)); var playlistItem = PlaylistItem.Create(item, _dlnaManager.GetProfile(deviceInfo.Name, deviceInfo.ModelName, deviceInfo.ModelNumber, deviceInfo.Manufacturer));
playlistItem.StartPositionTicks = startPostionTicks; playlistItem.StartPositionTicks = startPostionTicks;
if (playlistItem.IsAudio) if (playlistItem.IsAudio)
@ -485,7 +485,7 @@ namespace MediaBrowser.Dlna.PlayTo
_updateTimer.Stop(); _updateTimer.Stop();
_disposed = true; _disposed = true;
_device.Dispose(); _device.Dispose();
_logger.Log(LogSeverity.Debug, "PlayTo - Controller disposed"); _logger.Log(LogSeverity.Debug, "Controller disposed");
} }
} }
} }

View File

@ -243,8 +243,7 @@ namespace MediaBrowser.Dlna.PlayTo
/// <returns>The TranscodeSettings for the device</returns> /// <returns>The TranscodeSettings for the device</returns>
private void GetProfileSettings(DeviceInfo deviceProperties) private void GetProfileSettings(DeviceInfo deviceProperties)
{ {
var profile = _dlnaManager.GetProfile(deviceProperties.DisplayName, deviceProperties.ModelName, var profile = _dlnaManager.GetProfile(deviceProperties.Name, deviceProperties.ModelName, deviceProperties.ModelNumber, deviceProperties.Manufacturer);
deviceProperties.ModelNumber);
if (!string.IsNullOrWhiteSpace(profile.Name)) if (!string.IsNullOrWhiteSpace(profile.Name))
{ {