草庐IT

边界条件

全部标签

javascript - 寻找算法来找到颜色区域的边界

我有一个画有图像的Canvas。当用户点击图片时,我需要找到用户点击的颜色区域。一个区域被定义为一组4路连接的像素,其颜色与被点击的像素相同。我需要一个可以用来在Canvas上设置剪切路径的形式的区域,这样我就可以用渐变等填充该区域。是否有有效的算法来寻找边界?比洪水填充算法更优化的东西(我不需要填充,我只需要在我的区域周围找到一条路径)。 最佳答案 我相信MooreNeighborhood追踪算法会做你想做的事。根据定义,MooreNeighborhood着眼于8连通性,但您应该能够轻松地将其调整为4连通性。如果您测试8-连通性,

javascript - 有没有一种方法只有在条件为真时才执行 jQuery 链接的分支

我对jQuery的熟练程度大概是7或8分(从1到10分),所以我不确定这是否有意义,但我想知道是否有人知道jQuery函数或可能是一个插件,它允许仅在给定条件为真时才执行jQuery的分支。否则,我很想听听是否有人认为这个概念在某些方面存在缺陷(编辑和如何它是有缺陷的)虽然可以使用类似于以下的普通JavaScript语法来控制各种事件的附件:vardesiredElement=$('.parent')//findtheparentelement.hover(overFunction,offFunction)//attachaneventwhileI'vegottheparentin's

javascript - 将指定排序条件的对象数组排序为字符串

我想要一个函数,通过获取一个包含属性名称和排序方向的字符串作为输入来对对象数组进行排序。我需要这样的东西:varmyArray=[{name:"A",age:30},{name:"B",age:20},{name:"C",age:20}];varstrSort="ageasc,namedesc";varsortedArray=customSortFuntion(myArray,strSort);//sortedArray==[{name:"C",age:20},{name:"B",age:20},{name:"A",age:30}]functioncustomSortFuntion(m

javascript - 通过特殊条件语句弄清楚

我将向您展示我的应用程序的一小部分,我想知道哪种方法是放置我正在处理的条件的正确方法。如果我将向您展示的两种方式都是正确的,我希望您能告诉我后果/逆境if((some.thing===''||0)||(some.how===''||0)){//somethingisgoingonhere}到目前为止我就是这样,有什么不好的地方吗?或者应该这样更好:if((some.thing===''||some.thing===0)||(some.how===''||some.how===0)){//somethingisgoingonhere}那么你有什么建议呢?最后结果一样吗?编辑添加另一种方式

javascript - 如何修复 d3 制图栅格重投影上的 map 边界?

我尝试使用thisexample之后的map的光栅重投影.如果我将示例kavrayskiy7投影更改为等距方位Angular投影,varprojection=d3.geo.azimuthalEquidistant().scale(90).translate([width/2,height/2]).clipAngle(180-1e-3).precision(.1);它应该将地球投影到一个圆盘上(投影图的图像)。然而,光栅重投影超出了该圆盘并用扩展图片填充整个Canvas(逆投影函数不是单射的,map上的几个x/y点对应于一个经/纬度坐标)。在原来的例子中,这应该用行来避免if(λ>180

javascript - `display: none` 与 React 中的条件渲染

我无法确定React中这两种渲染模式之间的区别。希望有人可以阐明这个问题。模式一:React的条件渲染https://facebook.github.io/react/docs/conditional-rendering.htmlclassListextendsReact.Component{state={menu:false,}handleMouseOver=()=>{this.setState({menu:true});}handleMouseLeave=()=>{this.setState({menu:false});}render(){const{menu}=this.stat

javascript - Vuejs Router,JavaScript代码的条件加载

我正在将VueRouter集成到我的应用程序中。在我的一个组件中,我正在使用一些js代码,我不想在另一条路线上加载或出现这些代码?例子compA.vueconsole.log('hello')app.com/a->IshouldseeconsolelogHello.app.com/b->whenIaccessthisIshouldnotseehellointheconsole.编辑:根据回复进行澄清。我有两个组件,每个组件都有自己的生命周期Hook,所以我不需要设置逻辑来触发基于组件的函数...如果用户访问compA并且函数触发并产生一些副作用,当我访问compB时,我希望没有类似于传

javascript - 条件 .then 执行

如何有条件地跳过promise而不做任何事情。我创建了一个嵌套的promise,我有7个.then's。但有条件地,我需要跳过几个.then并且在那个block中什么都不做,如何实现这个?我的完整代码:constadmin=require('firebase-admin');constrp=require('request-promise');module.exports=function(req,res){constphone=String(req.body.phone).replace(/[^\d]/g,'');constamount=parseInt(req.body.amoun

javascript - 继续检查条件而不是一次性检查 jquery/js

我想实现的是当鼠标没有悬停在menu3上时,系统会不断检查aboutMenu是否悬停,如果是,则提示'h',否则提示'nh'。问题是当鼠标离开menu3时只检查一次,如何解决这个问题?谢谢。$('#menu3').live('mouseout',function(){$("#aboutMenu").hover(function(){$(this).data("hovered",true);},function(){$(this).data("hovered",false);});if($("#aboutMenu").data("hovered")){alert('h');}else{a

javascript - 有条件的 promise

在我的脚本中,我需要检索字典以将编码值转换为名称:$.ajax({//retrievedictionary}).done(function(dictionary){//convertencodedvaluesintonames}).done(function(){//runmyapplication});但是,有时字典已经被另一个应用程序加载,在这种情况下我不需要ajax调用:if(dictionary){//convertencodedvaluesintonames//runmyapplication}else{$.ajax({//retrievedictionary}).done(