2024-08-02 14:25:54 +10:00
|
|
|
use crate::{FilterMode, GetSize, Size, WrapMode};
|
2024-09-28 15:07:55 +10:00
|
|
|
use windows::Win32::Foundation::E_NOINTERFACE;
|
2022-11-30 17:38:05 +11:00
|
|
|
use windows::Win32::Graphics::Direct3D11;
|
2024-09-28 15:07:55 +10:00
|
|
|
use windows::Win32::Graphics::Direct3D11::{ID3D11Texture2D, D3D11_RESOURCE_DIMENSION_TEXTURE2D};
|
2022-11-30 17:35:20 +11:00
|
|
|
|
2022-11-27 07:55:14 +11:00
|
|
|
impl From<WrapMode> for Direct3D11::D3D11_TEXTURE_ADDRESS_MODE {
|
|
|
|
fn from(value: WrapMode) -> Self {
|
|
|
|
match value {
|
|
|
|
WrapMode::ClampToBorder => Direct3D11::D3D11_TEXTURE_ADDRESS_BORDER,
|
|
|
|
WrapMode::ClampToEdge => Direct3D11::D3D11_TEXTURE_ADDRESS_CLAMP,
|
|
|
|
WrapMode::Repeat => Direct3D11::D3D11_TEXTURE_ADDRESS_WRAP,
|
|
|
|
WrapMode::MirroredRepeat => Direct3D11::D3D11_TEXTURE_ADDRESS_MIRROR,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<FilterMode> for Direct3D11::D3D11_FILTER {
|
|
|
|
fn from(value: FilterMode) -> Self {
|
|
|
|
match value {
|
|
|
|
FilterMode::Linear => Direct3D11::D3D11_FILTER_MIN_MAG_MIP_LINEAR,
|
2023-01-30 13:19:18 +11:00
|
|
|
FilterMode::Nearest => Direct3D11::D3D11_FILTER_MIN_MAG_MIP_POINT,
|
2022-11-27 07:55:14 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-08-02 14:25:54 +10:00
|
|
|
|
|
|
|
impl GetSize<u32> for Direct3D11::ID3D11RenderTargetView {
|
|
|
|
type Error = windows::core::Error;
|
|
|
|
|
|
|
|
fn size(&self) -> Result<Size<u32>, Self::Error> {
|
2024-09-28 15:07:55 +10:00
|
|
|
let parent: ID3D11Texture2D = unsafe {
|
|
|
|
let resource = self.GetResource()?;
|
|
|
|
if resource.GetType() != D3D11_RESOURCE_DIMENSION_TEXTURE2D {
|
|
|
|
return Err(windows::core::Error::new(
|
|
|
|
E_NOINTERFACE,
|
|
|
|
"expected ID3D11Texture2D as the resource for the view.",
|
|
|
|
));
|
|
|
|
}
|
|
|
|
// SAFETY: We know tha the resource is an `ID3D11Texture2D`.
|
|
|
|
// This downcast is safe because ID3D11Texture2D has ID3D11Resource in its
|
|
|
|
// inheritance chain.
|
|
|
|
//
|
|
|
|
// This check + transmute is cheaper than doing `.cast` (i.e. `QueryInterface`).
|
|
|
|
std::mem::transmute(resource)
|
|
|
|
};
|
2024-08-02 14:25:54 +10:00
|
|
|
|
|
|
|
let mut desc = Default::default();
|
|
|
|
unsafe {
|
|
|
|
parent.GetDesc(&mut desc);
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(Size {
|
|
|
|
height: desc.Height,
|
|
|
|
width: desc.Width,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl GetSize<u32> for Direct3D11::ID3D11ShaderResourceView {
|
|
|
|
type Error = windows::core::Error;
|
|
|
|
|
|
|
|
fn size(&self) -> Result<Size<u32>, Self::Error> {
|
2024-09-28 15:07:55 +10:00
|
|
|
let parent: ID3D11Texture2D = unsafe {
|
|
|
|
let resource = self.GetResource()?;
|
|
|
|
if resource.GetType() != D3D11_RESOURCE_DIMENSION_TEXTURE2D {
|
|
|
|
return Err(windows::core::Error::new(
|
|
|
|
E_NOINTERFACE,
|
|
|
|
"expected ID3D11Texture2D as the resource for the view.",
|
|
|
|
));
|
|
|
|
}
|
|
|
|
// SAFETY: We know tha the resource is an `ID3D11Texture2D`.
|
|
|
|
// This downcast is safe because ID3D11Texture2D has ID3D11Resource in its
|
|
|
|
// inheritance chain.
|
|
|
|
//
|
|
|
|
// This check + transmute is cheaper than doing `.cast` (i.e. `QueryInterface`).
|
|
|
|
std::mem::transmute(resource)
|
|
|
|
};
|
2024-08-02 14:25:54 +10:00
|
|
|
let mut desc = Default::default();
|
|
|
|
unsafe {
|
|
|
|
parent.GetDesc(&mut desc);
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(Size {
|
|
|
|
height: desc.Height,
|
|
|
|
width: desc.Width,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|