VS2012 未安装发布所需的WEB扩展

VS2012 未安装发布所需的WEB扩展,第1张

源程序的问题吧。重新下载一个安装看看。 1、下载后得到ios文件,直接解压缩或用虚拟光驱加载运行,以管理员身份运行“vs_ultimate.exe”开始正式安装 2、提示用的电脑要安装ie10,不然有些功能将无法使用,这个有用户自行选择是否要安装

在开始之前,先准备Visual Studio 2012 SDK

安装好SDK后,进入VS。先新建一个Project,在“其它项目类型”那里找到“Visual Studio Package”

接下来的对话框里,选“C#”,然后基本是下一步。在最后一步把那两个复选框取消,因为那个在这里没什么用处。最后就成功新建了个VS扩展的Project

三、初步改造

第一步我们给VS加上背景图。首先对Project添加WPF的程序集为引用,有四个,分别为“PresentationCore”、“PresentationFramework”、“System.Xaml”、“WindowsBase”。然后打开“XXXPackage.cs”(XXX一般为这个Project的名字)文件,代码如下:

usingMicrosoft.VisualStudio.Shell

usingMicrosoft.VisualStudio.Shell.Interop

using System

using System.Runtime.InteropServices

using System.Windows

using System.Windows.Controls

using System.Windows.Media

using System.Windows.Media.Imaging

namespace Moen.IDEBackground //命名空间自己修改回自己用的

{

[PackageRegistration(UseManagedResourcesOnly = true)]

[InstalledProductRegistration("#110", "#112","1.0", IconResourceID = 400)]

[Guid(GuidList.guidIDE_BackgroundPkgString)]

[ProvideAutoLoad(UIContextGuids.NoSolution)]

[ProvideAutoLoad(UIContextGuids.SolutionExists)]

public sealed class IDEBackgroundPackage :Package

{

protected override void Initialize()

{

base.Initialize()

Application.Current.MainWindow.Loaded += MainWindow_Loaded

}

void MainWindow_Loaded(object sender, RoutedEventArgs e)

{

var rWindow = (Window)sender

//加载图片

var rImageSource =BitmapFrame.Create(new Uri(@"G:\Picture\Pool\絵师100人展02_p109.png"/*图片路径*/),BitmapCreateOptions.None, BitmapCacheOption.OnLoad)

rImageSource.Freeze()

var rImageControl = new Image()

{

Source = rImageSource,

Stretch =Stretch.UniformToFill, //按比例填充

HorizontalAlignment =HorizontalAlignment.Center, //水平方向中心对齐

VerticalAlignment =VerticalAlignment.Center, //垂直方向中心对齐

}

Grid.SetRowSpan(rImageControl, 4)

var rRootGrid =(Grid)rWindow.Template.FindName("RootGrid", rWindow)

rRootGrid.Children.Insert(0, rImageControl)

}

}

}

代码修改一下后,调试,这时就会编译扩展,然后启动实验用VS。(如果这是第一次启动实验用VS,可能要像刚安装完VS那样设置一下)接着你会看到角落处显现出那张背景图

(免调试进入实验用VS方法:开始菜单->Microsoft Visual Studio 2012->Microsoft Visual Studio SDK->Tools->Start Experimental Instance of Visual Studio 2012)

四、修改皮肤配色

为了方便,在实验用VS处进入“工具->扩展功能和更新程序”,选“在线”部分,然后在中间找到“Visual Studio 2012 Color ThemeEditor”并安装,重启实验用VS

重启后,进入“工具->CustomizeColors”。本例子已深色为基础,于是在左边“New Theme”处,直接在文本框输入一个皮肤名,然后点“Create”。这样就进入了皮肤配色表

首先把主界面那一大块灰色给除掉。找到“Environment→ EnvironmentBackgroundGradient”为开头的,统统都把不透明度设为0。然后点表左上角的“Save andApply Theme”,关掉所有页面。然后你就会看到背景啦

再继续,找到“Environment→ MainWindowActiveCaption”、“Environment→ MainWindowInactiveCaption”、“Environment→ CommandShelfBackgroundGradientXXX”、“Environment→ CommandShelfHighlightGradientXXX”、“Environment→ CommandBarGradientXXX”、“Environment→ CommandBarToolBarBorder”,都把不透明度设为0,

然后应用。上面那部分灰色的也没啦

至于这些是对应哪里的呢,可以通过那名字来确定,不过不准。要详细弄清楚很麻烦,要用反编译软件反要修改的控件的xaml文档,找到对应的画刷名。非常复杂,所以我这里提供我自己用的。在“Customize Colors”那里点“Import Theme”即可

五、编辑器

到目前为止,打开文件后,编辑器的背景还是黑的。接下来就是把这层黑的去掉

先打开“source.extension.vsixmanifest”文件,进入“Assets”选项卡,单击“New”按钮。在d出的对话框里,“Type”选“Microsoft.VisualStudio.MefComponent”,“Source”选“Aproject in current solution”,“Project”选当前的Project,目前应该就一个选项的。最后OK

接下来新建一个文件,这里就叫“EditorBackground.cs”

在输入代码前添加几个引用——System.ComponentModel.Composition、Microsoft.VisualStudio.CoreUtility、Microsoft.VisualStudio.Text.UI、Microsoft.VisualStudio.Text.UI.Wpf(后三个在“扩展”处找)

搞定后文件代码如下:

usingMicrosoft.VisualStudio.Text.Classification

usingMicrosoft.VisualStudio.Text.Editor

usingMicrosoft.VisualStudio.Utilities

usingSystem

usingSystem.ComponentModel.Composition

usingSystem.Windows

usingSystem.Windows.Controls

usingSystem.Windows.Media

using System.Windows.Threading

namespaceMoen.IDEBackground

{

[Export(typeof(IWpfTextViewCreationListener))]

[ContentType("Text")]

[ContentType("BuildOutput")]

[TextViewRole(PredefinedTextViewRoles.Document)]

class Listener : IWpfTextViewCreationListener

{

[Import]

IEditorFormatMapServiceEditorFormatMapService = null

public voidTextViewCreated(IWpfTextView rpTextView)

{

new EditorBackground(rpTextView)

//去掉断点边栏的背景

var rProperties =EditorFormatMapService.GetEditorFormatMap(rpTextView).GetProperties("IndicatorMargin")

rProperties["BackgroundColor"] = Colors.Transparent

rProperties["Background"]= Brushes.Transparent

}

}

class EditorBackground

{

IWpfTextView r_TextView

ContentControl r_Control

Grid r_ParentGrid

Canvas r_ViewStack

public EditorBackground(IWpfTextViewrpTextView)

{

r_TextView = rpTextView

r_Control = (ContentControl)r_TextView

r_TextView.Background =Brushes.Transparent

r_TextView.BackgroundBrushChanged+= TextView_BackgroundBrushChanged

r_TextView.Closed +=TextView_Closed

r_Control.Loaded +=TextView_Loaded

}

void MakeBackgroundTransparent()

{

r_TextView.Background =Brushes.Transparent

r_ViewStack.Background =Brushes.Transparent

r_ParentGrid.ClearValue(Grid.BackgroundProperty)

}

void TextView_Loaded(object sender,RoutedEventArgs e)

{

if (r_ParentGrid == null)

r_ParentGrid =(Grid)r_Control.Parent

if (r_ViewStack == null)

r_ViewStack =(Canvas)r_Control.Content

MakeBackgroundTransparent()

}

voidTextView_BackgroundBrushChanged(object sender, BackgroundBrushChangedEventArgse)

{

r_Control.Dispatcher.BeginInvoke(new Action(() =>

{

while (r_ParentGrid.Background!= null)

MakeBackgroundTransparent()

}), DispatcherPriority.Render)

}

void TextView_Closed(object sender,EventArgs e)

{

//清除委托,以防内存泄露

r_TextView.Closed -=TextView_Closed

r_TextView.BackgroundBrushChanged-= TextView_BackgroundBrushChanged

}

}

}

调试进入实验用VS,进入配色表,找到“Environment →EnvironmentBackground”,设置一个颜色值(我这里是#A0000000),作为编辑器的背景色。再找到“Environment → Window”设置为透明

六、结尾

基本的VS界面改造就是这么多了。不过有个棘手的问题——xaml编辑器和个别的编辑器(如HTML的)因为是承载在VS的一个子窗口上,而这个窗口的背景是黑色的。目前仍在研究中……


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11719141.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存