Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/272.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何从图像裁剪器获取多个图像url_C#_Umbraco - Fatal编程技术网

C# 如何从图像裁剪器获取多个图像url

C# 如何从图像裁剪器获取多个图像url,c#,umbraco,C#,Umbraco,我有一个关于多重图像裁剪器的问题,首先我用我的图像媒体类型上的图像裁剪器属性替换了默认的文件上载属性。我正在使用多媒体选择器上载多个图像,我的问题是如何在surface controller中获取图像URL 这就是我所做的 var docsId=Umbraco.TypedContent(Convert.ToInt32(document.Get(“id”)); var imageList=docsId.GetPropertyValue(“图像”).GetCropUrl(宽:329,高:200) 但

我有一个关于多重图像裁剪器的问题,首先我用我的图像媒体类型上的图像裁剪器属性替换了默认的文件上载属性。我正在使用多媒体选择器上载多个图像,我的问题是如何在surface controller中获取图像URL

这就是我所做的

var docsId=Umbraco.TypedContent(Convert.ToInt32(document.Get(“id”));
var imageList=docsId.GetPropertyValue(“图像”).GetCropUrl(宽:329,高:200)

但是它说,“不能将类型“string”隐式转换为“System.Collections.Generic.List”

我尝试了另一种选择,我尝试了这个代码

var docsId=Umbraco.TypedContent(Convert.ToInt32(document.Get(“id”));
var imageList=docsId.GetPropertyValue(“图像”).GetCropUrl(宽:329,高:200)

在umbraco.dll中再次出现错误“类型为”System.ArgumentNullException”的异常,但未在用户代码中处理

希望任何人都能帮助解决这个问题。我刚到翁布拉科

谢谢,

@Harvey- 这是
文档

var searcher = new IndexSearcher(indexDirectory, true);

var masterQuery = new BooleanQuery();

TopDocs resp = searcher.Search(masterQuery, null, searcher.MaxDoc());

foreach (var scoreDoc in resp.ScoreDocs) {
    var document = searcher.Doc(scoreDoc.doc);
    var docsId = Umbraco.TypedContent(Convert.ToInt32(document.Get("id")));
    var imageList = docsId.GetPropertyValue<string>("images").GetCropUrl(width: 329, height: 200);
}
var searcher=newindexsearcher(indexDirectory,true);
var masterQuery=new BooleanQuery();
TopDocs resp=searcher.Search(masterQuery,null,searcher.MaxDoc());
foreach(相应ScoreDocs中的var scoreDoc){
var document=searcher.Doc(scoreDoc.Doc);
var docsId=Umbraco.TypedContent(Convert.ToInt32(document.Get(“id”));
var imageList=docsId.GetPropertyValue(“图像”).GetCropUrl(宽:329,高:200);
}

.GetCropUrl
需要类型
System.Collections.Generic.List
,但您正在尝试使用类型
字符串

将代码更改为以下内容:

var docsId = Umbraco.TypedContent(Convert.ToInt32(document.Get("id")));
var imageList = Url.GetCropUrl(docsId, propertyAlias: "images", height: 200, width: 329);

请阅读使用图像裁剪器。

我假设
文档
是一个Umbraco内容节点。并且此文档有一个别名为
图像的
多媒体选择器

因此,您已经获得了类型为
ippublishedcontent
文档

var document = Umbraco.TypedContent(Convert.ToInt32(document.Get("id")));
多介质选取器
以逗号分隔存储所选取介质的ID:
1124、1130、1401、
,因此首先需要将ID放入数组:

var imageIds = docsId.GetPropertyValue<string>("images").Split(',');
然后,您可以使用for循环获取每个图像的裁剪图像的url:

for (var image in imageList) 
{
    var imageCropUrl = image.GetCropUrl(width: 329, height: 200);
    <img src="imageCropUrl"></img>
}
for(imageList中的var图像)
{
var imageCropUrl=image.GetCropUrl(宽:329,高:200);
}

两段已发布的代码之间有什么区别?文档的类型是什么
i发布的内容
?@Harvey,感谢您的及时回复
文档
就是这样的
GetPropertyValue
。您使用的是什么版本的Umbraco?先生,我已经这样做了,但它在我的控制器中给我错误
“UrlHelper”不包含“GetCropUrl”的定义和最佳扩展方法重载“urlHelperEnderextesions.GetCropUrl”(UrlHelper,IPPublishedContent,int?,int?,string,string,int?,ImageCropMode?,ImageCropChor?,bool,bool,bool,string,ImageCropRadioMode?,bool,bool)’需要类型为“UrlHelper”的接收器。
for (var image in imageList) 
{
    var imageCropUrl = image.GetCropUrl(width: 329, height: 200);
    <img src="imageCropUrl"></img>
}