summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 1e36ccd)
raw | patch | inline | side by side (parent: 1e36ccd)
author | Alvin Penner <penner@vaxxine.com> | |
Sat, 28 Aug 2010 14:00:44 +0000 (10:00 -0400) | ||
committer | Alvin Penner <penner@vaxxine.com> | |
Sat, 28 Aug 2010 14:00:44 +0000 (10:00 -0400) |
share/extensions/pathscatter.inx | patch | blob | history | |
share/extensions/pathscatter.py | patch | blob | history |
index 8f45aa75a441943d813b31ffa9dbaccce0d68b83..19d2e081066fa9e21db4eb9c40526acfed093f96 100644 (file)
<_option value="clone">Cloned</_option>
</param>
<param name="duplicate" type="boolean" _gui-text="Duplicate the pattern before deformation">true</param>
+ <param name="grouppick" type="boolean" _gui-text="If pattern is a group, pick group members">false</param>
+ <param name="pickmode" type="optiongroup" _gui-text="Pick group members:">
+ <_option value="rand">Randomly</_option>
+ <_option value="seq">Sequentially</_option>
+ </param>
<effect>
<object-type>all</object-type>
<effects-menu>
index 03da822c514a2822a7c796e952384a4641cfe027..a7a77e1eca9fc1b1547e03a95dc6afec947c8d5a 100644 (file)
self.OptionParser.add_option("-t", "--toffset",
action="store", type="float",
dest="toffset", default=0.0, help="tangential offset")
+ self.OptionParser.add_option("-g", "--grouppick",
+ action="store", type="inkbool",
+ dest="grouppick", default=False,
+ help="if pattern is a group then randomly pick group members")
+ self.OptionParser.add_option("-m", "--pickmode",
+ action="store", type="string",
+ dest="pickmode", default="rand",
+ help="group pick mode (rand=random seq=sequentially)")
self.OptionParser.add_option("-f", "--follow",
action="store", type="inkbool",
dest="follow", default=True,
#id = self.options.ids[-1]
id = idList[-1]
self.patternNode=self.selected[id]
-
+
self.gNode = etree.Element('{http://www.w3.org/2000/svg}g')
self.patternNode.getparent().append(self.gNode)
inkex.errormsg(_("This extension requires two selected paths."))
return
self.prepareSelectionList()
-
+
#center at (0,0)
bbox=pathmodifier.computeBBox([self.patternNode])
mat=[[1,0,-(bbox[0]+bbox[1])/2],[0,1,-(bbox[2]+bbox[3])/2]]
width=bbox[1]-bbox[0]
dx=width+self.options.space
+ #check if group and expand it
+ patternList = []
+ if self.options.grouppick and (self.patternNode.tag == inkex.addNS('g','svg') or self.patternNode.tag=='g') :
+ mat=simpletransform.parseTransform(self.patternNode.get("transform"))
+ for child in self.patternNode:
+ simpletransform.applyTransformToNode(mat,child)
+ patternList.append(child)
+ else :
+ patternList.append(self.patternNode)
+ #inkex.debug(patternList)
+
+ counter=0
for skelnode in self.skeletons.itervalues():
self.curSekeleton=cubicsuperpath.parsePath(skelnode.get('d'))
for comp in self.curSekeleton:
s=self.options.toffset
while s<=length:
mat=self.localTransformAt(s,self.options.follow)
+ if self.options.pickmode=="rand":
+ clone=copy.deepcopy(patternList[random.randint(0, len(patternList)-1)])
- clone=copy.deepcopy(self.patternNode)
+ if self.options.pickmode=="seq":
+ clone=copy.deepcopy(patternList[counter])
+ counter=(counter+1)%len(patternList)
+
#!!!--> should it be given an id?
#seems to work without this!?!
- myid = self.patternNode.tag.split('}')[-1]
+ myid = patternList[random.randint(0, len(patternList)-1)].tag.split('}')[-1]
clone.set("id", self.uniqueId(myid))
self.gNode.append(clone)