اندازهی قلم متن
تخمین مدت زمان مطالعهی مطلب:
سه دقیقه
در قسمت قبلی، به Bindingها پرداختیم و در این قسمت قصد بررسی Triggers و موارد پیشرفتهتر در Bindings را داریم. در مثالهای قسمت قبل علاوه بر Bind کردن View به View Model، مثالی را داشتیم که در آن View به View بایند شده بود (Text یک Label به Text یک Entry بایند شده بود، به شکلی که هر آنچه که در Entry تایپ میشد، در همان لحظه روی Label نیز دیده میشد). خب در آن مثال، Text در هر دو کنترل از یک جنس بود (string).
اما اگر بخواهیم مثلا زمانی که روی Entry فوکوس شده، متن آن Bold شود چه؟ در این صورت، IsFocused ای که از جنس bool است، به FontAttributes ای که یک Enum شامل موارد Italic/Bold و ... است، بایند شدهاست. زمانی که دو طرف Binding از یک جنس نباشند، راهکارهایی باید اتخاذ شوند که Trigger یکی از آنهاست. برای پیاده سازی این مثال داریم:
<Entry FontAttributes="Italic"> <Entry.Triggers> <Trigger TargetType="Entry" Property="IsFocused" Value="True"> <Setter Property="FontAttributes" Value="Bold" /> </Trigger> </Entry.Triggers> </Entry>
این کد میگوید زمانیکه IsFocused برابر با True است، FontAttributes برابر با Bold شود. دقت کنید که مقدار اولیه FontAttributes در این مثال برابر با Italic بودهاست. اگر Trigger ای بنا بر شرایطی، مقداری را عوض کند، وقتی آن شرایط برقرار نباشد، کارهایش را ملغی (Rollback) میکند. برای همین، در این مثال، وقتی Focus را از روی Entry برداریم، دوباره متن Italic میشود!
علاوه بر Trigger، ما DataTrigger نیز داریم. مثال اولیه XamApp که یک Button را داشتیم و با هر بار زدن بر روی آن مقدار StepsCount که به یک Label وصل بود، یکی یکی افزایش میافت، به خاطر بیاورید. فرض کنید در ابتدا که StepsCount برابر با صفر است، قصد نمایش Label را نداریم. مقدار StepsCount که از جنس int است و در View Model است، قرار است اگر صفر باشد، IsVisible مربوط به Label که bool است، False شود. در این صورت داریم:
<Label Text="{Binding StepsCount, StringFormat='{}Button tapped {0} times!'}"> <Label.Triggers> <DataTrigger TargetType="Label" Binding="{Binding StepsCount}" Value="0"> <Setter Property="IsVisible" Value="False" /> </DataTrigger> </Label.Triggers> </Label>
در فولدر Converters در فولدر Views در پروژه XamApp کلاس زیر را اضافه کنید:
public class StepsCountToFontAttributesConverter : Converter<int, FontAttributes> { protected override FontAttributes Convert(int value, Type targetType, object parameter, CultureInfo culture) { if (value % 2 == 0) /* راه تشخیص زوج بودن یک عدد */ return FontAttributes.Bold; return FontAttributes.Italic; } }
<Label FontAttributes="{Binding StepsCount, Converter={converters:StepsCountToFontAttributesConverter}}" Text="{Binding StepsCount, StringFormat='{}Button tapped {0} times!'}" />
علاوه بر موارد فوق، Event Trigger نیز وجود دارد. برای مثال، زمانیکه روی دکمهای کلیک میشود، یک Label با Animation ای Fade out شود. برای این کار نگاهی به پروژه Xamanimation بیاندازید.