Updated PlayTo profiles and recognition
This commit is contained in:
parent
d55af4f529
commit
db3b106fe0
|
@ -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>
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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))
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue
Block a user