def read(self, stream: Stream, version): self.color = stream.read_object('color') self.size_z = stream.read_double('size z') self.type = stream.read_int('type', expected=(0, 1, 2, 3, 4, 5, 6)) self.quality = stream.read_double('quality') # 0->1 self.symbol_level = SymbolLayer.read_symbol_level(stream) self.z_rotation = stream.read_double('z rotation') self.x_offset = stream.read_double('x offset') self.y_offset = stream.read_double('y offset') self.z_offset = stream.read_double('z offset') stream.read_ushort('unknown', expected=65535) self.dx = stream.read_double('dx') self.dy = stream.read_double('dy') self.dz = stream.read_double('dz') self.x_rotation = stream.read_double('x rotation') self.y_rotation = stream.read_double('y rotation') self.width = stream.read_double('width') self.depth_y = stream.read_double('depth y') self.keep_aspect_ratio = stream.read_ushort('keep aspect ratio') != 0 self.billboard_display = stream.read_ushort('display front face') != 0
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.size = stream.read_double('size') type_code = stream.read_int() type_dict = { 0: 'circle', 1: 'square', 2: 'cross', 3: 'x', 4: 'diamond' } if type_code not in type_dict: raise UnreadableSymbolException( 'Unknown marker type at {}, got {}'.format(hex(stream.tell() - 4), type_code)) stream.log('found a {}'.format(type_dict[type_code]), 4) self.type = type_dict[type_code] self.symbol_level = SymbolLayer.read_symbol_level(stream) self.angle = stream.read_double('angle') self.x_offset = stream.read_double('x offset') self.y_offset = stream.read_double('y offset') self.outline_enabled = stream.read_uchar('has outline') != 0 self.outline_width = stream.read_double('outline width') self.outline_color = stream.read_object('outline color') if version > 1: self.rotate_with_transform = stream.read_ushort('rotate with transform') != 0
def read(self, stream: Stream, version): self.symbol_level = SymbolLayer.read_symbol_level(stream) # consume unused properties - MultiLayerMarkerSymbol implements IMarkerSymbol # so that the size/offsets/angle are required properties. But they aren't used # or exposed anywhere for MultiLayerMarkerSymbol _ = stream.read_double('unused marker size') _ = stream.read_double('unused marker x/y/offset or angle') _ = stream.read_double('unused marker x/y/offset or angle') _ = stream.read_double('unused marker x/y/offset or angle') _ = stream.read_object('unused color') self.halo = stream.read_int() == 1 self.halo_size = stream.read_double('halo size') self.halo_symbol = stream.read_object('halo') # useful stuff number_layers = stream.read_int('layers') for i in range(number_layers): layer = stream.read_object('symbol layer {}/{}'.format(i + 1, number_layers)) self.layers.extend([layer]) for l in self.layers: l.read_enabled(stream) for l in self.layers: l.read_locked(stream) if version > 1: _ = stream.read_double('unknown size') _ = stream.read_double('unknown size') if version >= 3: for l in self.layers: l.read_tags(stream)
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.width = stream.read_double('width') self.type = stream.read_int('type', expected=(0, 1, 2)) self.quality = stream.read_double('quality') self.symbol_level = SymbolLayer.read_symbol_level(stream)
def read(self, stream: Stream, version): self.texture = stream.read_object('texture') self.color = stream.read_object('color') self.transparency_color = stream.read_object('transparency color') self.outline = stream.read_object('outline') self.angle = stream.read_double('angle') self.size = stream.read_double('size') stream.read_int('raster op', expected=13) self.symbol_level = stream.read_int('level')
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.unicode = stream.read_int('unicode') self.units = stream.read_int('units') self.angle = stream.read_double('angle') self.size = stream.read_double('size') self.depth = stream.read_double('depth') self.normalized_origin_x = stream.read_double('normalized origin x') self.normalized_origin_y = stream.read_double('normalized origin y') self.normalized_origin_z = stream.read_double('normalized origin z') self.x_offset = stream.read_double('x offset') self.y_offset = stream.read_double('y offset') self.z_offset = stream.read_double('z offset') self.font = stream.read_object('font') self.read_symbol_level(stream) stream.read_ushort('unknown', expected=65535) self.character_marker_symbol = stream.read_object('character marker') self.vertical_orientation = stream.read_uchar( 'vertical orientation') != 0 self.x_rotation = stream.read_double('x rotation') self.y_rotation = stream.read_double('y rotation') self.width = stream.read_double('width') self.maintain_aspect_ratio = stream.read_ushort( 'maintain aspect ratio') != 0 self.billboard_display = stream.read_ushort('billboard display') != 0
def read(self, stream: Stream, version): self.ramp = stream.read_object('Color ramp') self.fill_color = stream.read_object('fill color') # either an entire LineSymbol or just a LineSymbolLayer self.outline = stream.read_object('outline') self.percent = stream.read_double('percent') self.intervals = stream.read_uint('intervals') self.angle = stream.read_double('angle') self.type = stream.read_uint('Gradient type') self.symbol_level = SymbolLayer.read_symbol_level(stream)
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.size = stream.read_double('size') self.width = stream.read_double('width') self.angle = stream.read_double('angle') self.style = stream.read_uint('style') self.symbol_level = SymbolLayer.read_symbol_level(stream) self.x_offset = stream.read_double('x offset') self.y_offset = stream.read_double('y offset') self.rotate_with_transform = stream.read_ushort('rotate with transform') != 0
def read(self, stream: Stream, version): self.flip = stream.read_uchar('flip') != 0 self.offset = stream.read_double('offset') self.pattern_marker = stream.read_object('pattern marker') self.template = stream.read_object('template') self.decoration = stream.read_object('decoration') self.symbol_level = SymbolLayer.read_symbol_level(stream) self.decoration_on_top = stream.read_uchar('decoration on top') != 0 self.line_start_offset = stream.read_double('line start offset') self.cap = self.read_cap(stream) self.join = self.read_join(stream) self.miter_limit = stream.read_double('miter limit')
def read(self, stream: Stream, version): self.pattern_interval = stream.read_double('pattern interval') pattern_part_count = stream.read_int('pattern parts') self.pattern_parts = [] for p in range(pattern_part_count): filled_squares = stream.read_double() empty_squares = stream.read_double() self.pattern_parts.append([filled_squares, empty_squares]) pattern = '' for p in self.pattern_parts: pattern += '-' * int(p[0]) + '.' * int(p[1]) stream.log('deciphered line pattern {} ending'.format(pattern))
def read(self, stream: Stream, version): _ = stream.read_double('unused double') _ = stream.read_double('unused double') self.line = stream.read_object('pattern line') # either an entire LineSymbol or just a LineSymbolLayer self.outline = stream.read_object('outline') self.angle = stream.read_double('angle') self.offset = stream.read_double('offset') self.separation = stream.read_double('separation') self.symbol_level = SymbolLayer.read_symbol_level(stream)
def read(self, stream: Stream, version): """ Reads the decoration information """ self.fixed_angle = not bool(stream.read_uchar()) stream.log('detected {}'.format( 'fixed angle' if self.fixed_angle else 'not fixed angle')) self.flip_first = bool(stream.read_uchar()) stream.log('detected {}'.format( 'flip first' if self.flip_first else 'no flip first')) self.flip_all = bool(stream.read_uchar()) stream.log('detected {}'.format( 'flip all' if self.flip_all else 'no flip all')) self.position_as_ratio = stream.read_ushort('position as ratio') != 0 self.marker = stream.read_object('marker') # next bit is the number of doubles coming next marker_number_positions = stream.read_uint('marker positions') # next bit is the positions themselves -- maybe we can infer this from the number of positions # alone. E.g. 2 positions = 0, 1. 3 positions = 0, 0.5, 1 for _ in range(marker_number_positions): self.marker_positions.append(stream.read_double()) stream.log('marker positions are {}'.format(self.marker_positions))
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.width = stream.read_double('width') self.line_type = self.read_line_type(stream) stream.log('read line type of {}'.format(self.line_type)) self.symbol_level = SymbolLayer.read_symbol_level(stream)
def read(self, stream: Stream, version): if version in (3, 4, 5): self.picture = stream.read_object('picture') elif version in (7, 8): _ = stream.read_ushort('pic version?') _ = stream.read_uint('picture type?') self.picture = stream.read_object('picture') elif version == 9: self.picture = Picture.create_from_stream(stream) if version < 4: _ = stream.read_object() if version <= 8: _ = stream.read_object() self.color_foreground = stream.read_object('color 1') self.color_background = stream.read_object('color 2') if version >= 9: self.color_transparent = stream.read_object('color 3') self.angle = stream.read_double('angle') self.size = stream.read_double('size') self.x_offset = stream.read_double('x offset') self.y_offset = stream.read_double('y offset') self.x_scale = stream.read_double('x scale') self.y_scale = stream.read_double('y scale') self.symbol_level = SymbolLayer.read_symbol_level(stream) self.swap_fb_gb = bool(stream.read_uchar('swap fgbg')) self.rotate_with_transform = stream.read_ushort( 'rotate with transform') != 0 if version < 5: return stream.read_int('unknown', expected=0) stream.read_ushort('unknown', expected=0) if version == 7: return if 5 < version <= 8: size = stream.read_int('unknown size') stream.read(size)
def read(self, stream: Stream, version): self.random = bool(stream.read_int('random')) self.offset_x = stream.read_double('offset x') self.offset_y = stream.read_double('offset y') self.separation_x = stream.read_double('separation x') self.separation_y = stream.read_double('separation y') _ = stream.read_double('unused double') _ = stream.read_double('unused double') self.marker = stream.read_object('fill marker') # either an entire LineSymbol or just a LineSymbolLayer self.outline = stream.read_object('outline') self.symbol_level = SymbolLayer.read_symbol_level(stream) self.grid_angle = stream.read_double('grid angle')
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.size_z = stream.read_double('size z') self.geometry = stream.read_object('multipatch') stream.read_int('unknown', expected=9) self.origin_x = stream.read_double('origin x') self.origin_y = stream.read_double('origin y') self.origin_z = stream.read_double('origin z') self.material_draping = stream.read_ushort('no material draping') == 0 stream.read_int('unknown', expected=13) stream.read_int('unknown', expected=0) self.rotation_z = stream.read_double('rotation z') self.offset_x = stream.read_double('offset x') self.offset_y = stream.read_double('offset y') self.offset_z = stream.read_double('offset z') stream.read_ushort('unknown', expected=65535) self.picture = stream.read_object('picture') self.rotation_x = stream.read_double('rotation x') self.rotation_y = stream.read_double('rotation y') self.size_x = stream.read_double('size x') self.size_y = stream.read_double('size y') self.keep_aspect = stream.read_ushort('keep aspect') != 0 stream.read_ushort('unknown', expected=0) if version == 7: return self.display_face_front = stream.read_ushort('display face front') != 0 if version < 7: stream.read_int('unknown', expected=0) stream.read_double('unknown') stream.read_ushort('unknown', expected=0) stream.read_ushort('unknown', expected=65535) if version > 8: stream.read_ushort('unknown', expected=0) stream.read_int('unknown', expected=0)
def read(self, stream: Stream, version): self.color = stream.read_object('color') self.unicode = stream.read_int('unicode') self.angle = stream.read_double('angle') self.size = stream.read_double('size') self.x_offset = stream.read_double('x offset') self.y_offset = stream.read_double('y offset') self.x_scale = stream.read_double('x scale') self.y_scale = stream.read_double('y scale') if version <= 2: self.std_font = stream.read_object('font') self.font = self.std_font.font_name self.symbol_level = SymbolLayer.read_symbol_level(stream) if version > 1: self.rotate_with_transform = stream.read_ushort('rotate with transform') != 0 if version >= 3: self.font = stream.read_string('font name') # lot of unknown stuff stream.read_double('unknown 3', expected=0) # or object? stream.read_double('unknown 4', expected=0) # or object? stream.read_int('font weight') stream.read_int('unknown', expected=0) stream.read_int('font size * 10000') / 10000 if version >= 4: # std OLE font .. maybe contains useful stuff like bold/etc, but these aren't exposed in ArcGIS anyway.. self.std_font = stream.read_object('font')
def read(self, stream: Stream, version): if version <= 4: self.picture = stream.read_object('picture') elif version == 7: _ = stream.read_ushort('pic version?') _ = stream.read_uint('picture type?') self.picture = stream.read_object('picture') elif version == 8: self.picture = Picture.create_from_stream(stream) self.color_background = stream.read_object('color bg') self.color_foreground = stream.read_object('color fg') self.color_transparent = stream.read_object('color trans') # either an entire LineSymbol or just a LineSymbolLayer self.outline = stream.read_object('outline') self.angle = stream.read_double('angle') self.scale_x = stream.read_double('scale_x') self.scale_y = stream.read_double('scale_y') self.offset_x = stream.read_double('offset x') self.offset_y = stream.read_double('offset y') self.separation_x = stream.read_double('separation x') self.separation_y = stream.read_double('separation y') stream.read(16) self.symbol_level = SymbolLayer.read_symbol_level(stream) self.swap_fb_gb = bool(stream.read_uchar('swap fgbg')) if version < 4: return stream.read(6) if 4 < version < 8: stream.read(4)
def read(self, stream: Stream, version): has_picture = stream.read_int('has picture') != 0 stream.read_int('unknown') stream.read_int('unknown') stream.read_int('unknown') stream.read_int('unknown') stream.read_int('unknown') stream.read_int('unknown') stream.read_int('unknown') stream.read_int('unknown') self.transparency = stream.read_double('transparency') self.color = stream.read_object('color') self.transparent_texture_color = stream.read_object('transparent texture color') if has_picture: self.picture = BmpPicture() self.picture.read(stream, 1)
def read(self, stream: Stream, version): stream.read_uchar('unknown', expected=0) self.offset = stream.read_double('offset') self.width = stream.read_double('width') self.fill_symbol = stream.read_object('fill symbol')
def read(self, stream: Stream, version): self.width = stream.read_double('width') self.texture_fill_symbol = stream.read_object('texture fill symbol') self.vertical_orientation = stream.read_uchar( 'vertical orientation') != 0