C# 如何将照片显示到组织结构图?SharePoint 2013

C# 如何将照片显示到组织结构图?SharePoint 2013,c#,sharepoint,sharepoint-2010,sharepoint-2013,C#,Sharepoint,Sharepoint 2010,Sharepoint 2013,我的清单如下: 我有一个基于以下列表的组织结构图: 我需要在名称上方显示来自发布图像的图像,并且它也是发布图像列类型如何显示它 这是我的代码:我正在使用谷歌图表与C#,我需要图像与100x60px public partial class OrganizationChartUserControl : UserControl { //Get the List name to fetch the data from string listName = "OrgChart_Demo";

我的清单如下:

我有一个基于以下列表的组织结构图:

我需要在名称上方显示来自
发布图像
的图像,并且它也是
发布图像
列类型如何显示它

这是我的代码:我正在使用谷歌图表与C#,我需要图像与100x60px

public partial class OrganizationChartUserControl : UserControl
{
    //Get the List name to fetch the data from
    string listName = "OrgChart_Demo";
    int iRowCounter = 0;
    string sAllNewRows = string.Empty;

    protected void Page_Load(object sender, EventArgs e)
    {
        //Fetch the data (recursively) from the list
        GetNode(string.Empty);

        //Generate the Client Script and Register
        GenerateClientScript(sAllNewRows);
    }

    private void GenerateClientScript(string sAllNewRows)
    {
        string csName1 = "OrgChartScript";
        Type csType = this.GetType();

        ClientScriptManager cs = Page.ClientScript;

        // Check to see if the startup script is already registered. 
        if (!cs.IsStartupScriptRegistered(csType, csName1))
        {
            StringBuilder cstext = new StringBuilder();
            cstext.Append("<script type='text/javascript' src='https://www.google.com/jsapi'></script>");
            cstext.Append("<script type='text/javascript'>");
            cstext.Append("google.load('visualization', '1', { packages: ['orgchart'] });");
            cstext.Append("google.setOnLoadCallback(drawChart);");

            cstext.Append("function drawChart() {");
            cstext.Append("var data = new google.visualization.DataTable();");

            cstext.Append("data.addColumn('string', 'Name');");
            cstext.Append("data.addColumn('string', 'Manager');");
            cstext.Append("data.addColumn('string', 'ToolTip');");
            cstext.Append("var rowArr = new Array();");

            cstext.Append(sAllNewRows);

            cstext.Append("data.addRows(rowArr);");

            cstext.Append("var chart = new google.visualization.OrgChart(document.getElementById('chart_div'));");
            cstext.Append("chart.draw(data, { allowHtml: true, allowCollapse: true });");
            cstext.Append("}");
            cstext.Append("</script>");
            cs.RegisterClientScriptBlock(csType, csName1, cstext.ToString(), false);

        }

    }

    private void GetNode(string reportsTo)
    {
        SPListItemCollection itemCol = GetListItems(listName, reportsTo);

        foreach (SPListItem item in itemCol)
        {
            //create a new row
            sAllNewRows += createNewRow(item);

            //Recursion
            GetNode(item["Name"].ToString());
        }

    }

    private string createNewRow(SPListItem listItem)
    {
        string sName = ConvertTo.CastIn<string>(listItem["Name"]);
        string sTitle = ConvertTo.CastIn<string>(listItem["Title"]);
        string sMoreInfo = ConvertTo.CastIn<string>(listItem["MoreInfo"]);
        string sReportsTo = ConvertTo.CastIn<string>(listItem["ReportsTo"]);

       // string sReportsTo = new SPFieldLookupValue(ConvertTo.CastIn<string>(listItem["ReportsTo"])).LookupValue;

        StringBuilder sText = new StringBuilder();
        sText.Append("var NewRow = new Array();");
        sText.Append(String.Format("NewRow.push({{ v: '{0}', f: '{1}<div style=\"color:red; font-style:italic\">{2}</div>' }});", sName, sName, sTitle));
        sText.Append(String.Format("NewRow.push('{0}');", sReportsTo));
        sText.Append(String.Format("NewRow.push('{0}');", sMoreInfo));
        sText.Append(String.Format("rowArr[{0}] = NewRow;", iRowCounter));

        iRowCounter++;
        return sText.ToString();
    }

    private SPListItemCollection GetListItems(string destList, string reportsTo)
    {
        SPListItemCollection ResultListItems = null;

        using (SPSite oSite = new SPSite(SPContext.Current.Web.Url))
        {
            using (SPWeb oWeb = oSite.OpenWeb())
            {
                SPList list = oWeb.Lists.TryGetList(destList);
                if (null == list)
                    return ResultListItems;

                //Check if the item already exist.
                StringBuilder sCAMLQuery = new StringBuilder(string.Empty);
                sCAMLQuery.Append("<Where>");
                if (reportsTo != string.Empty)
                {
                    sCAMLQuery.Append("<Eq>");
                    sCAMLQuery.Append("<FieldRef Name='ReportsTo' />");
                  //  sCAMLQuery.Append("<Value Type='Lookup'>" + reportsTo + "</Value>");
                    sCAMLQuery.Append("<Value Type='Text'>" + reportsTo + "</Value>");

                    sCAMLQuery.Append("</Eq>");
                }
                else
                {
                    sCAMLQuery.Append("<IsNull>");
                    sCAMLQuery.Append("<FieldRef Name='ReportsTo' />");
                    sCAMLQuery.Append("</IsNull>");
                }
                sCAMLQuery.Append("</Where>");

                SPQuery QueryResult = new SPQuery();
                QueryResult.Query = sCAMLQuery.ToString();
                ResultListItems = list.GetItems(QueryResult);
            }
        }

        return ResultListItems;
    }
}
公共部分类OrganizationChartUserControl:UserControl
{
//获取要从中获取数据的列表名
string listName=“OrgChart\u Demo”;
int iRowCounter=0;
string sAllNewRows=string.Empty;
受保护的无效页面加载(对象发送方、事件参数e)
{
//从列表中(递归)获取数据
GetNode(string.Empty);
//生成客户端脚本并注册
GenerateClientScript(sAllNewRows);
}
私有void GenerateClientScript(字符串sAllNewRows)
{
字符串csName1=“OrgChartScript”;
类型csType=this.GetType();
ClientScriptManager cs=Page.ClientScript;
//检查启动脚本是否已注册。
如果(!cs.isstartupscript已注册(csType,csName1))
{
StringBuilder cstext=新建StringBuilder();
cstext.Append(“”);
cstext.Append(“”);
追加(“google.load('visualization','1',{packages:['orgchart']});”;
Append(“google.setOnLoadCallback(drawChart);”;
Append(“函数drawChart(){”);
追加(“var data=new google.visualization.DataTable();”;
追加(“data.addColumn('string','Name');”;
追加(“data.addColumn('string','Manager');”;
追加(“data.addColumn('string','ToolTip');”;
Append(“var rowArr=new Array();”;
cstext.Append(sAllNewRows);
追加(“data.addRows(rowArr);”;
Append(“var chart=new google.visualization.OrgChart(document.getElementById('chart_div'));”;
Append(“chart.draw(数据,{allowtml:true,allowCollapse:true});”;
cstext.Append(“}”);
cstext.Append(“”);
cs.RegisterClientScriptBlock(csType,csName1,cstext.ToString(),false);
}
}
私有void GetNode(字符串reportsTo)
{
SPListItemCollection itemCol=GetListItems(listName,reportsTo);
foreach(itemCol中的SPListItem项)
{
//创建新行
sAllNewRows+=createNewRow(项目);
//递归
GetNode(项[“名称”].ToString());
}
}
私有字符串createNewRow(SPListItem listItem)
{
字符串sName=ConvertTo.CastIn(listItem[“Name”]);
string-sTitle=ConvertTo.CastIn(listItem[“Title”]);
字符串sMoreInfo=ConvertTo.CastIn(listItem[“MoreInfo”]);
字符串sReportsTo=ConvertTo.CastIn(listItem[“ReportsTo”]);
//字符串sReportsTo=newspfieldlookupvalue(ConvertTo.CastIn(listItem[“ReportsTo”])).LookupValue;
StringBuilder sText=新的StringBuilder();
Append(“var NewRow=newarray();”;
Append(String.Format(“NewRow.push({v:{0}',f:{1}{2}}}});”,sName,sName,sTitle));
Append(String.Format(“NewRow.push('{0}');”,sReportsTo));
Append(String.Format(“NewRow.push('{0}');”,sMoreInfo));
Append(String.Format(“rowArr[{0}]=NewRow;”,iRowCounter));
iRowCounter++;
返回sText.ToString();
}
私有SPListItemCollection GetListItems(字符串destList、字符串reportsTo)
{
SPListItemCollection ResultListItems=null;
使用(SPSite oSite=newspsite(SPContext.Current.Web.Url))
{
使用(SPWeb oWeb=oSite.OpenWeb())
{
SPList list=oWeb.Lists.TryGetList(destList);
if(null==列表)
返回结果列表项;
//检查项目是否已存在。
StringBuilder sCAMLQuery=新的StringBuilder(string.Empty);
sCAMLQuery.Append(“”);
if(reportsTo!=string.Empty)
{
sCAMLQuery.Append(“”);
sCAMLQuery.Append(“”);
//sCAMLQuery.Append(“+reportsTo+”);
sCAMLQuery.Append(“+reportsTo+”);
sCAMLQuery.Append(“”);
}
其他的
{
sCAMLQuery.Append(“”);
sCAMLQuery.Append(“”);
sCAMLQuery.Append(“”);
}
sCAMLQuery.Append(“”);
SPQuery QueryResult=新建SPQuery();
QueryResult.Query=sCAMLQuery.ToString();
ResultListItems=list.GetItems(QueryResult);
}
}
返回结果列表项;
}
}
请帮帮我。
谢谢大家!

我解决了这个问题,它不再重要,但对于那些将来会有这个问题的人来说。唯一需要更改的行是:

sText.Append(String.Format(“NewRow.push({v:{0}',f:{2}{3}}}});”,sName,sPicture,sName,sTitle))


感谢@hardik解决了我的问题

你为什么用这个问题滥发语言标签?这样做会使问题的定义过于宽泛。@HovercraftFullOfEels谢谢你的建议,我认为这会让我更著名的问题:P:)是的,你对这个问题给予了更多的关注,但大部分都是多余的关注。请使您的标签更加具体。@HovercraftFullOfEels谢谢您,我已修复了我的标签。这个问题有什么答案吗?不知道,因为我只懂Java,你们的问题和Java编程无关。