Windows phone 之 UserControl的应用
一、新建一个UserControl.xaml页面 MyUserControl.xaml
添加代码如下:
<UserControl x:Class="bodypicture.MyUserControl"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
d:DesignHeight="480" d:DesignWidth="480">
<Grid x:Name="LayoutRoot">
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="0,0,12,0">
<Image Canvas.ZIndex="4" Name="image1" Stretch="Fill" Width="200" Height="200" Margin="52,255,216,313">
<Image.RenderTransform>
<SkewTransform AngleX="0" AngleY="0" CenterX="0" CenterY="0"></SkewTransform>
</Image.RenderTransform>
</Image>
<Image Name="image2" Height="200" Stretch="Fill" Margin="252,256,66,312">
<Image.RenderTransform>
<TransformGroup>
<SkewTransform AngleX="0" AngleY="-20" CenterX="0" CenterY="0">
</SkewTransform>
</TransformGroup>
</Image.RenderTransform>
</Image>
<Image Name="image3" Source="image/3.png" Width="210" Height="50" Stretch="Fill" Margin="187,206,71,512">
<Image.RenderTransform>
<TransformGroup>
<SkewTransform AngleX="-70" AngleY="0" CenterX="0" CenterY="0">
</SkewTransform>
</TransformGroup>
</Image.RenderTransform>
</Image>
</Grid>
</Grid>
</UserControl>
这样就可以在另一个页面Page1.xaml直接引用该UserContro.xaml页面了。
二、在Page1.xaml页面中。
之前,添加命名空间
xmlns:my="clr-namespace:bodypicture"
<!--LayoutRoot 是包含所有页面内容的根网格-->
<Grid x:Name="LayoutRoot" Background="LightPink">
<toolkit:GestureService.GestureListener>
<toolkit:GestureListener DragStarted="OnGestureListenerDragStarted"
DragDelta="OnGestureListenerDragDelta"
DragCompleted="OnGestureListenerDragCompleted"
/>
</toolkit:GestureService.GestureListener>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<!--ContentPanel - 在此处放置其他内容--> ////就是这一句了××××××××××××××××××××××××××××××××××××××××××××
<my:MyUserControl></my:MyUserControl>
</Grid>
刚开始,我在Page1.xaml.cs
添加如下代码:
MyUserControl u = new MyUserControl(); u.image1.Source = new BitmapImage(new Uri(image_array[imgi], UriKind.Relative)); u.image2.Source = new BitmapImage(new Uri(image_array[imgj], UriKind.Relative));
运行程序,发现图片没有显示,经过若干挣扎。。才发现,
我不能这么写:MyUserControl u = new MyUserControl();因为这相当于重新实例化了一个类MyUserControl,不再是Page1.xaml的UserControl了,这样怎么会显示数据呢?
所以,修改如下:
<my:MyUserControl x:Name="userControl"></my:MyUserControl>
给MyUserControl命名。
然后,在Page1.xaml.cs中就可以直接使用了,不用实例化了。
userControl.image1.Source = new BitmapImage(new Uri(image_array[imgi], UriKind.Relative)); userControl.image2.Source = new BitmapImage(new Uri(image_array[imgj], UriKind.Relative));
ok,图片成功显示。
当然,也可以在MyUserControl.XAML.CS页面中,定义属性。
private string image11;
public string Image1
{
get { return image11; }
set
{
image11 = value;
BitmapImage bit1 = new BitmapImage(new Uri(image11, UriKind.Relative));
image1.Source = bit1;
}
}
private string image22;
public string Image2
{
get { return image22; }
set
{
image22 = value;
image2.Source = new BitmapImage(new Uri(image22, UriKind.Relative));
}
}
这样,在Page1.xaml.cs中或者Page1.xaml中都可以使用Image1、Image2属性进行设置他们的图片来源。
这就需要根据情况进行选择了。
Windows phone 之 UserControl的应用的更多相关文章
- [個人紀錄] windows form , usercontrol design 模式不見
windows form 跟 usercontrol 都變成cs檔 無法點擊進入設計模式 <Compile Include="Form1.cs"/> <Compi ...
- silverlight ListBox 多列图片效果
这个功能之前用wpf写过一次这次用Silverlight写一次 这两种写法上基本上没有太大的差别 这个Demo并不完美,只是给大家提供一个思路 源码:SilverLightListPricture.r ...
- wpf中,一个简单的自定义treeview
首先创建一个自定义控件,在里面定义好treeview的样式,将本来的三角形的图标变为加号的图标,并且添加节点之间的连线. <UserControl x:Class="TreeViewE ...
- 基于WPF系统框架设计(9)-多值绑定之IMultiValueConverter
应用场景 我想把View层的一个布局控件和功能按钮传到ViewModel层,达到动态变更布局,同时灵活获取功能按钮的属性,让View和ViewModel完全分离,而不受View层影响. 最后我想到使用 ...
- WPF实现软键盘
wpf 实现一个软键盘, 先发个图: 工作有需要实现一个软键盘,本来想用windows自带的软键盘凑合凑合得了,又觉得那个软键盘太大了,所以自己实现了一个. 说一下实现的思路,其实没什么思路 界面就是 ...
- 用户控件的设计要点 System.Windows.Forms.UserControl
用户控件的设计要点 最近的项目中有一个瀑布图(彩图)的功能,就是把空间和时间上的点量值以图的形式呈现出来,如下图: X坐标为空间,水平方向的一个像素代表一个空间单位(例如50米) Y坐标为时间,垂直方 ...
- 背水一战 Windows 10 (77) - 控件(控件基类): ContentControl, UserControl, Page
[源码下载] 背水一战 Windows 10 (77) - 控件(控件基类): ContentControl, UserControl, Page 作者:webabcd 介绍背水一战 Windows ...
- Windows phone 自定义用户控件(UserControl)——ColorPicker
编码前 学习Windows phone自定义用户控件,在<WPF编程宝典>学习的小例子.并根据windows phone稍微的不同,做了点修改.ColorPicker(颜色拾取器):拥有三 ...
- [Windows Phone学习笔记]UserControl的使用
UserControl的使用 开发过程中,多个UI控件需要协同工作,相互交互之后,才可完成一个完整的业务需求,此时可把这些控件封装成为一个整体,相互之间的交互逻辑封装其中,外部调用可无需关心内部逻辑, ...
随机推荐
- nyoj 1100 WAJUEJI which home strong!
WAJUEJI which home strong! 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 在一个山沟里,姐弟俩同时考上了大学.但由于家里拮据,所以这并不是 ...
- uva 1030 - Image Is Everything(迭代更新)
题目链接:uva 1030 - Image Is Everything 题目大意:有一个最大为n*n*n的立方体的一个不规整立体,由若干个1*1*1的小正方体构成(每一个小正方体被涂成不同的颜色),给 ...
- 安卓开发中Theme.AppCompat.Light的解决方法
styles.xml中<style name="AppBaseTheme" parent="Theme.AppCompat.Light">提示如下错 ...
- JSON和JAVA的POJO的相互转换【转载】
该类中用用到的jar包:参加文章<使用json-lib进行Java和JSON之间的转换[转载]> import java.util.Collection; import java.util ...
- Bulk Insert命令具体
Bulk Insert命令具体 BULK INSERT以用户指定的格式复制一个数据文件至数据库表或视图中. 语法: BULK INSERT [ [ 'database_name'.][ 'owner' ...
- Apache Solr配置
Solr配置 Solr的主要功能是全文检索,该功能分为两个过程:创建索引和对索引进行搜索: 在创建索引之前,需要重点关注两个配置文件:SOLR_HOME/collection1/conf/schema ...
- careercup-链表 2.4
2.4 编写代码,以给定值x为基准将链表分割成两部分,所有小于x的结点排在大于或等于x的结点之前. 思路:将小于的结点还是保存在原来的链表中,将大于等于x的结点加入一个新的链表,最后将这两个链表链接起 ...
- SOA体系结构之基础培训教程-大纲篇
引言: 最近受邀做了一个企业的SOA体系结构的内训,本文是内训课程的培训大纲,分享一下吧,希望大家能够喜欢.同时也想针对大纲中列出的内容对SOA架构体系做一次回顾,如果时间允许把完整的课件也想放上来共 ...
- 解锁Scott过程中出现的问题及解决办法
一.conn sys/sys as sysdba; //以DBA的身份登录 出现以下错误 经查 协议适配器错误的问题的原因有三个 监听服务没有起起来.windows平台个一如下操作:开始---程序-- ...
- eclipse中svn插件的安装
Svn(Subversion)是近年来崛起的版本管理工具,在当前的开源项目里(J2EE),几乎95%以上的项目都用到了SVN.Subversion项目的初衷是为了替换当年开源社区最为流行的版本控制软件 ...