在cppwinrt

时间:2017-12-18 23:47:55

标签: c++ c++-winrt

使用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 ++编程。

2 个答案:

答案 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.