Style trong lập trình WPF

Lập trình WPF cơ bản

5.0 (3 đánh giá)
Tạo bởi Kteam Cập nhật lần cuối 23:58 13-05-2023 76.542 lượt xem 3 bình luận
Tác giả/Dịch giả: Kteam
Học nhanh

Danh sách bài học

Style trong lập trình WPF

Dẫn nhập

Sức mạnh của hệ điều hành Window là không thể chối cãi. Và để tạo nên sức mạnh đó không thể thiếu những ứng dụng mạnh mẽ. Vậy để tạo ra những ứng dụng đó, người lập trình viên cần học cái gì? Lập trình Winform thật sự rất mạnh. Nhưng vẫn còn những giới hạn. Vậy cùng nhau vượt qua các giới hạn đó với Lập trình WPF.

Nội dung

Tổng quan lập trình WPF

Download project

MainWindow.xaml.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace Style___WPF
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }
    }
}

MainWindow.xaml

<Window x:Class="Style___WPF.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="350" Width="525">
    <Window.Resources>
        <ResourceDictionary Source="StyleResource.xaml"></ResourceDictionary>
        
    </Window.Resources>
    <StackPanel>
        <Grid>
            <Grid.Resources>
                <Style TargetType="Button">
                    <Setter Property="Width" Value="150"></Setter>
                    <Setter Property="Background" Value="Aqua"></Setter>
                </Style>
                <Style TargetType="TextBox">
                    <Setter Property="Width" Value="150"></Setter>
                    <Setter Property="Background" Value="Aqua"></Setter>
                </Style>
                
            </Grid.Resources>
            <Button Content="HowKteam.com" HorizontalAlignment="Left">
            </Button>
            <Button Content="HowKteam.com" HorizontalAlignment="Right">
            </Button>
            <TextBox Width="100"></TextBox>
        </Grid>     
        <StackPanel>
            <StackPanel.Resources>
                <Style TargetType="Button" x:Key="btnStylePurple">
                    <Setter Property="Width" Value="150"></Setter>
                    <Setter Property="Background" Value="Purple"></Setter>
                </Style>
                <Style TargetType="Button" x:Key="btnStyleOrange">
                    <Setter Property="Width" Value="150"></Setter>
                    <Setter Property="Background" Value="Orange"></Setter>
                </Style>
            </StackPanel.Resources>
            <Button Content="Free Education" Style="{StaticResource btnStylePurple}">
            </Button>
            <Button Content="Free Education" Style="{StaticResource btnStyleOrange}">
            </Button>
        </StackPanel>
        <StackPanel>
            <Button Content="Share to be better"></Button>
            <TextBox Text="K9">
                <TextBox.Background>
                    <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                        <GradientStop Color="Black" Offset="0"/>
                        <GradientStop Color="#FFA5EA2E" Offset="0.648"/>
                    </LinearGradientBrush>
                </TextBox.Background>

            </TextBox>
        </StackPanel>
        <StackPanel>
            <Button Content="Mushi" Background="{StaticResource colorGardien}" Style="{StaticResource ResourceKey=btnStyleFrom_ResourceFile}">               
            </Button>
        </StackPanel>
    </StackPanel>
</Window>

StyleResource.xaml

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <Style TargetType="Button" x:Key="btnStyleFrom_ResourceFile">
        <Setter Property="Width" Value="150"></Setter>
        <Setter Property="Background" Value="Green"></Setter>
    </Style>
    <LinearGradientBrush x:Key="colorGardien" EndPoint="0.5,1" StartPoint="0.5,0">
        <GradientStop Color="Black" Offset="0"/>
        <GradientStop Color="#FFE647FF" Offset="1"/>
    </LinearGradientBrush>
</ResourceDictionary>

Kết luận

Bài sau chúng ta sẽ cùng nhau tìm hiểu về DataTemplate trong lập trình WPF nhé.

Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của mình để phát triển bài viết tốt hơn. Đừng quên “Luyện tập – Thử thách – Không ngại khó”.


Tải xuống

Tài liệu

Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Style trong lập trình WPF dưới dạng file PDF trong link bên dưới.

Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com

Đừng quên likeshare để ủng hộ Kteam và tác giả nhé!

Project

Nếu việc thực hành theo hướng dẫn không diễn ra suôn sẻ như mong muốn. Bạn cũng có thể tải xuống PROJECT THAM KHẢO ở link bên dưới!


Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.

Nội dung bài viết

Tác giả/Dịch giả

Khóa học

Lập trình WPF cơ bản

Lập trình WPF cơ bản

Đánh giá

Vo Tan Duc đã đánh giá 09:41 24-04-2022

Hay và tiện lợi ghê! Wonderful! Xin cảm ơn Kteam và anh Long đã tạo nên khóa học này. Hy vọng trong tương lai sẽ có những khóa học thực chiến WPF về phần mềm, tool,...

hanhtoan đã đánh giá 21:24 18-07-2021

Nội dung phong phú, đa dạng. Cảm ơn tác giả đã dành nhiều thời gian chia sẽ kinh nghiệm quý báu.

Dungvanphong đã đánh giá 21:05 27-06-2019

Bình luận

Để bình luận, bạn cần đăng nhập bằng tài khoản Howkteam.

Đăng nhập
Vo Tan Duc đã bình luận 10:04 24-04-2022

Người dùng có thể điều chỉnh Style không anh?

Nguyễn Hưng đã bình luận 08:08 03-09-2020

anh ơi sao button và textbox đều có giá trị width là 150 mà trên hình lại thấy độ rộng của textbox nhỏ hơn của 2 button ạ?

 

Không có video.