使用cppwinrt(标准C ++,而不是C ++ / CX)如何以编程方式将Button的内容设置为图像?必须以编程方式,因为cppwinrt还不支持xaml,其中这样做很容易。这是我正在尝试的内容,这会产生一个功能性但空的按钮:
Button button = Button();
BitmapImage bitmapImage = BitmapImage();
Uri imageUri = Uri(L"ms-appx:///Assets/Images/stopbutton.png");
bitmapImage.UriSource(imageUri);
Image buttonImage = Image();
buttonImage.Height(30);
buttonImage.Width(30);
buttonImage.Source(bitmapImage);
button.Content(buttonImage);
然后当然我添加了一个很好地显示的按钮,虽然是空白的。我已经尝试了.png的绝对路径,但也失败了。必须有一种方法可以用C ++编程。
答案 0 :(得分:1)
您的原始代码在我这边工作正常。只需确保您的图像确实位于Assets / Images文件夹中,您将其添加到项目中,并通过检查图像属性中的Content参数是否设置为True来在构建期间使用应用程序内容进行复制。
修改强> 阅读完您的进一步要求后。只需将按钮填充和边框粗细设置为零,这将删除图像周围的任何空间。
这是一个带有按钮创建代码的简单工作应用程序:
#include <winrt\Windows.ApplicationModel.Activation.h>
#include <winrt\Windows.Devices.Enumeration.h>
#include <winrt\Windows.Foundation.h>
#include <winrt\Windows.UI.Xaml.h>
#include <winrt\Windows.UI.Xaml.Controls.h>
#include <winrt\Windows.UI.Xaml.Media.Imaging.h>
using namespace winrt;
using namespace winrt::Windows::ApplicationModel::Activation;
using namespace winrt::Windows::Devices::Enumeration;
using namespace winrt::Windows::Foundation;
using namespace winrt::Windows::UI::Xaml;
using namespace winrt::Windows::UI::Xaml::Controls;
using namespace winrt::Windows::UI::Xaml::Media::Imaging;
struct App : ApplicationT<App>
{
void OnLaunched(LaunchActivatedEventArgs const &)
{
Image image;
image.Height(30);
image.Width(30);
image.Source(BitmapImage(Uri(L"ms-appx:///Assets/Images/sample.png")));
Button button;
button.Padding(ThicknessHelper::FromUniformLength(0));
button.BorderThickness(ThicknessHelper::FromUniformLength(0));
button.Content(image);
Window window = Window::Current();
window.Content(button);
window.Activate();
}
static void Initialize(ApplicationInitializationCallbackParams const &)
{
make<App>();
}
static void Start()
{
Application::Start(App::Initialize);
}
};
int WINAPI wWinMain(HINSTANCE, HINSTANCE, PWSTR, int)
{
App::Start();
}
答案 1 :(得分:0)
好的,这就是让按钮显示填充按钮的图像所需要的:而不是设置按钮。图像的内容,使用图像创建ImageBrush并设置按钮。返回到ImageBrush,例如
Button button = Button();
button.Height(30);
button.Width(30);
BitmapImage bitmapImage = BitmapImage();
Uri imageUri = Uri(L"ms-appx:///Assets/Images/stopbutton.png");
bitmapImage.UriSource(imageUri);
ImageBrush imageBrush = ImageBrush();
imageBrush.ImageSource(bitmapImage);
button.Background(imageBrush);
//The button will now look exactly like the image.