- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如代码所示,我添加了一支圆珠笔,它支持 30 种颜色,但还不够。
colorSelected(Color type)我是通过其他方式得到的,这里不讨论。现在我想点击圆珠笔,使用我的 colorSelected 来绘制。如何?谢谢。
<Grid>
<InkToolbar TargetInkCanvas="{x:Bind inkCanvas}" InitialControls="AllExceptPens" VerticalAlignment="Top">
<InkToolbarBallpointPenButton x:Name="ballpointPen" Click="xxx_Click"/>
<InkToolbarCustomToolButton x:Name="toolButtonColorPicker" Click="ToolButton_ColorPicker">
<Image Height="20" Width="20" Source="ms-appx:///Assets/Palette.png"/>
<ToolTipService.ToolTip>
<ToolTip Content="ColorPicker"/>
</ToolTipService.ToolTip>
</InkToolbarCustomToolButton>
</InkToolbar>
<InkCanvas x:Name="inkCanvas" Margin="0,48,0,0"/>
</Grid>
下面的代码似乎不起作用...
private void xxx_Click(object sender, RoutedEventArgs e)
{
if(bUserDefinedColor)
{
InkDrawingAttributes drawingAttributes = inkCanvas.InkPresenter.CopyDefaultDrawingAttributes();
drawingAttributes.Color = colorSelected;
inkCanvas.InkPresenter.UpdateDefaultDrawingAttributes(drawingAttributes);
}
}
顺便把测试工程上传到GitHub https://github.com/hupo376787/Test.git
最佳答案
这里有一个更好的解决方案,无需直接调用 UpdateDefaultDrawingAttributes
。
我会做的是,每当用户从您的ColorPicker
中选择一种新颜色并点击OK 时,将这种颜色添加到调色板
InkToolbarBallpointPenButton
,然后将 SelectedBrushIndex
设置为新创建颜色的索引。
您可以完全删除您的xxx_Click
处理程序,并将LeftClick
中的内容替换为以下内容
cpx.LeftClick += (ss, ee) =>
{
bUserDefinedColor = true;
colorSelected = cpx.pickerColor;
ballpointPen.Palette.Add(new SolidColorBrush(colorSelected));
ballpointPen.SelectedBrushIndex = ballpointPen.Palette.Count - 1;
};
就是这样!您会看到笔图标上所选颜色的视觉效果会自动反射(reflect)新颜色,从而提供出色的用户体验。
为了进一步增强用户体验,您可能还需要做两件事。
调色板
,以便下次用户打开应用程序时,它们仍然可用。 ColorPicker
,不如尝试将其放在 InkToolbarBallpointPenButton
的颜色弹出窗口中,这样所有颜色相关的东西都在同一个地方。位于此弹出窗口内的控件称为 InkToolbarPenConfigurationControl
。您应该能够找到它的样式(参见下面的路径)并将您的 ColorPicker
添加到它。C:\Program Files (x86)\Windows Kits\10\DesignTime\CommonConfiguration\Neutral\UAP\10.0.xxxxx.0\Generic\generic.xaml
希望这对您有所帮助!
关于c# - 如何设置inktoolbar的笔颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45768338/
我正在创建一个包含 InkCanvas 的 CustomControl。现在的问题是如何将 InkToolbar(位于 CustomControl 外部)链接到 InkCanvas(位于 Custom
新的 InkCanvas 和 InkToolbar(请参阅 this link )可以在 Windows 10 UWP HTML5/JS 应用中使用吗?我在文档中只看到 C#、C++ 和 VB 选项卡
我是一名优秀的程序员,十分优秀!