Hello<br><br>I haven't read all your code<br>but IMHO you should have a look to <br><a href="http://www.maths.lancs.ac.uk/~rowlings/Software/ratioRenderer/">http://www.maths.lancs.ac.uk/~rowlings/Software/ratioRenderer/</a><br>
which is a python renderer build as a qgis plugin !<br><br>Seb<br><br><div><span class="gmail_quote">2008/3/21, Anita Graser <<a href="mailto:anitagraser@gmx.at">anitagraser@gmx.at</a>>:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
For my project I want to visualise speed on streets with a continuous color renderer. I'd like it to show slow in red then change to yellow then to green. Unfortunately QgsContinuousColorRenderer only allows to use two colors. So I'm trying to write a new renderer inheriting QgsContinuousColor Renderer.<br>
<br> Is it possible to write a new renderer in python?<br> <br> I found some problems which I don't understand:<br> <br> 1.<br> I tried to rewirte the renderFeature function:<br> -------------------------------------------------------------<br>
def renderFeature(self, painter, feature, image, scalefactor, selected, widthScale=1):<br> attrs = feature.attributeMap()<br> fvalue = float(attrs[self.classificationField])<br> -------------------------------------------------------------<br>
However, attributeMap() seems to always return a dictionary of length 1 allthough there should be 12 attributes. So I can't get a value for fvalue.<br> <br> 2.<br> If I catch the exception caused by problem 1 and set a default value the function will continue to it's end. But then, I get a typeError:<br>
TypeError: invalid result type from My3ColorRenderer.renderFeature()<br> I'm confused because I thought that this function returns void ...<br> <br> Anyone got an idea what I'm doing wrong?<br> <br> Thank you!<br>
<br> My Code:<br> <br> -----------------------------------------------------------------<br> <br> from PyQt4.QtCore import *<br> from PyQt4.QtGui import *<br> from qgis.core import *<br> from qgis.gui import *<br> <br> class My3ColorRenderer(QgsContinuousColorRenderer):<br>
def __init__(self,vectorType):<br> self.vectorType=vectorType<br> QgsContinuousColorRenderer.__init__(self,vectorType)<br> <br> def setMiddleSymbol(self,symbol):<br> self.mMiddleSymbol=symbol<br>
def middleSymbol(self):<br> return self.mMiddleSymbol<br> <br> def name(self):<br> return "FleetVis3ColorRenderer"<br> <br> def symbols(self):<br> list=[]<br> list.append(self.mMinimumSymbol)<br>
list.append(self.mMiddleSymbol)<br> list.append(self.mMaximumSymbol)<br> return list<br> <br> def setClassificationField(self,id):<br> self.classificationField=id<br> <br> def renderFeature(self, painter, feature, image, scalefactor, selected, widthScale=1):<br>
#first find out the value for the classification attribute<br> # ??? i dont know why it doesnt work ...<br> attrs = feature.attributeMap()<br> try:<br> fvalue = float(attrs[self.classificationField])<br>
except:<br> fvalue=50.0<br> <br> minvalue = float(self.minimumSymbol().lowerValue())<br> maxvalue = float(self.maximumSymbol().lowerValue())<br> middlevalue = minvalue + maxvalue<br>
middlevalue=middlevalue/2<br> <br> mincolor=QColor()<br> maxcolor=QColor()<br> <br> if self.vectorType == QGis.Line or self.vectorType == QGis.Point:<br> mincolor = self.minimumSymbol().pen().color()<br>
middlecolor=self.middleSymbol().pen().color()<br> maxcolor = self.maximumSymbol().pen().color()<br> else:#if polygon<br> painter.setPen(self.minimumSymbol().pen())<br> mincolor = self.minimumSymbol().fillColor()<br>
middlecolor=self.middleSymbol().fillColor()<br> maxcolor = self.maximumSymbol().fillColor()<br> <br> if (maxvalue - minvalue)!=0:<br> if(fvalue<middlevalue):<br> red = int (middlecolor.red() * (fvalue - minvalue) / (middlevalue - minvalue) + mincolor.red() * (middlevalue - fvalue) / (middlevalue - minvalue))<br>
green = int (middlecolor.green() * (fvalue - minvalue) / (middlevalue - minvalue) + mincolor.green() * (middlevalue - fvalue) / (middlevalue - minvalue))<br> blue = int (middlecolor.blue() * (fvalue - minvalue) / (middlevalue - minvalue) + mincolor.blue() * (middlevalue - fvalue) / (middlevalue - minvalue))<br>
elif(fvalue==middlevalue):<br> red=int(middlecolor.red())<br> green=int(middlecolor.green())<br> blue=int(middlecolor.blue())<br> else:<br> red = int (maxcolor.red() * (fvalue - middlevalue) / (maxvalue - middlevalue) + middlecolor.red() * (maxvalue - fvalue) / (maxvalue - middlevalue))<br>
green = int (maxcolor.green() * (fvalue - middlevalue) / (maxvalue - middlevalue) + middlecolor.green() * (maxvalue - fvalue) / (maxvalue - middlevalue))<br> blue = int (maxcolor.blue() * (fvalue - middlevalue) / (maxvalue - middlevalue) + middlecolor.blue() * (maxvalue - fvalue) / (maxvalue - middlevalue))<br>
else:<br> red = int (mincolor.red())<br> green = int (mincolor.green())<br> blue = int (mincolor.blue())<br> <br> if self.vectorType == QGis.Point:<br> pen = self.minimumSymbol().pen()<br>
pen.setColor ( QColor(red, green, blue) )<br> pen.setWidthF ( widthScale * pen.width() )<br> <br> brush = self.minimumSymbol().brush()<br> <br> brush.setColor ( QColor(red, green, blue) )<br>
<br> brush.setStyle ( Qt.SolidPattern )<br> <br> img = QgsMarkerCatalogue.instance().imageMarker ( self.minimumSymbol().pointSymbolName(), self.minimumSymbol().pointSize(),pen, brush)<br> <br> if scalefactor:<br>
scalefactor = 1<br> <br> elif self.vectorType == QGis.Line:<br> painter.setPen( QPen(QColor(red, green, blue),int(widthScale*self.minimumSymbol().pen().width()) ))<br> <br> else:<br>
painter.setBrush(QColor(red, green, blue))<br> painter.setPen(Qt.NoPen)<br> <br><br> --<br> Ist Ihr Browser Vista-kompatibel? Jetzt die neuesten<br> Browser-Versionen downloaden: <a href="http://www.gmx.net/de/go/browser">http://www.gmx.net/de/go/browser</a><br>
_______________________________________________<br> Qgis-user mailing list<br> <a href="mailto:Qgis-user@lists.osgeo.org">Qgis-user@lists.osgeo.org</a><br> <a href="http://lists.osgeo.org/mailman/listinfo/qgis-user">http://lists.osgeo.org/mailman/listinfo/qgis-user</a><br>
</blockquote></div><br><br clear="all"><br>-- <br>Sébastien VIAL<br>Prof d'Info - Resp. TIC/Comm - Formateur SIG<br>Lycée Agricole du Balcon des Ardennes<br><a href="http://www.lebalcon.fr">http://www.lebalcon.fr</a><br>
tel : 03-24-57-66-71