Let me look that up in the dictionary for you.
There have been some changes to the VrPunt methods over time. I have suspected that not everything is implemented exactly the way it is documented, and sometimes a name could be different or missing. I have discovered though that the real magic is just in working with the dictionary which stores all the relevant LiDAR point attributes. The LiDAR data provider that we most often use stores the individual flight line tag in the "SOU" tag, Vr however will only filter by the "FLT" tag. Since FLT isn't used in our data, changing it to reflect the SOU value doesn't seem to have a downside. Below is a simple program that runs through all the point data and copies SOU to FLT. Now I can use the flight line filter to turn the points on and off.
print 'souflt.py modified 12:44 PM 8/27/2013'So the key is to load up the PuntA to make sure it is populated with the correct values, then modify the particular attribute and save it back to PuntA. When all the points are done re-record the entire Punt buffer. As of this writting the dictionary is organized as follows.
# Copy LiDAR Source attribute to Flight attribute
'''
Copyright 2013 Dennis Shimer
No warranties as to safety or usability expressed or implied.
Free to use, copy, modify, distribute with author credit.
Reads the "Source" in a PuntA dictionary and sets the "Flight" to the same value.
'''
Ws=PyVrWs()
Punt=PyVrPunt()
Gui=PyVrGui()
WsNum=Ws.Aws()
PointBufferCount=Ws.GetPuntBufCount(WsNum)
Ws.UndoBegin(WsNum,"Source2Flight")
Gui.ProgInit('Points',Ws.GetPuntBufCount(WsNum))
for PointBufferNumber in range(PointBufferCount):
Punt.Load(WsNum,PointBufferNumber)
Gui.ProgSet(PointBufferNumber)
for PointNum in range(Punt.GetCount()-1,-1,-1):
PuntA=Punt.GetPuntA(PointNum)
PuntA['Flt']=Punt.Sou(PointNum)
Punt.ChgPuntA (PointNum, PuntA)
Punt.ReRec()
Gui.ProgReset()
PyVrGr().Replot()
Ws.UndoEnd(WsNum)
"Lay" = 1 - Layer (1-30001)
"Int" = 0 - Intensity (0-65535)
"Dsp" = 1 - Display flag (0-1)
"Ret" = 0 - Return number (1-5)
"Nre" = 0 - Number of returns (1-5)
"Sdf" = 0 - Scan direction flag (0-1)
"Edg" = 0 - Edge of flight line flag (0-1)
"Cla" = 0 - Classification (0-31)
"Syn" = 0 - Synthetic flag (0-1)
"Key" = 0 - Key-point flag (0-1)
"Del" = 0 - Delete flag (0-1)
"Ang" = 0 - Scan angle (-90 - +90)
"Flt" = 0 - Flight number (0-255)
"Sou" = 0 - Point source Id (0-65535)
"Red" = 255 - Red component color (0-255)
"Green" = 255 - Green component color (0-255)
"Blue" = 255 - Blue component color (0-255)
"GpsTime" = 0.0 - GPS Time (Double precision number)
No comments:
Post a Comment