Source code for rna_tools.tools.pymol_drawing.pymol_drawing

#!/usr/bin/env python
import math


[docs] def draw_circle(x, y, z, r=8.0, cr=1.0, cg=0.4, cb=0.8, w=2.0): """ Create a CGO circle PARAMS x, y, z X, Y and Z coordinates of the origin r Radius of the circle cr, cg, cb Color triplet, [r,g,b] where r,g,b are all [0.0,1.0]. w Line width of the circle RETURNS the CGO object (it also loads it into PyMOL, too). """ x = float(x) y = float(y) z = float(z) r = abs(float(r)) cr = abs(float(cr)) cg = abs(float(cg)) cb = abs(float(cb)) w = float(w) obj = [BEGIN, LINES, COLOR, cr, cg, cb] for i in range(180): obj.append(VERTEX) obj.append(r * math.cos(i) + x) obj.append(r * math.sin(i) + y) obj.append(z) obj.append(VERTEX) obj.append(r * math.cos(i + 0.1) + x) obj.append(r * math.sin(i + 0.1) + y) obj.append(z) obj.append(END) cName = cmd.get_unused_name("circle_") cmd.load_cgo(obj, cName) cmd.set("cgo_line_width", w, cName) return obj
[docs] def draw_circle_selection(selName, r=None, cr=1.0, cg=0.4, cb=0.8, w=2.0): """ circleSelection -- draws a cgo circle around a given selection or object PARAMS selName Name of the thing to encircle. r Radius of circle. DEFAULT: This cript automatically defines the radius for you. If you select one atom and the resultant circle is too small, then you can override the script's calculation of r and specify your own. cr, cg, cb red, green and blue coloring, each a value in the range [0.0, 1.0] RETURNS The circle object. """ ((minX, minY, minZ), (maxX, maxY, maxZ)) = cmd.get_extent(selName) if r == None: r = max([maxX - minX, maxY - minY, maxZ - minZ]) stored.coords = [] cmd.iterate_state(1, selName, "stored.coords.append([x,y,z])") l = len(stored.coords) centerX = sum([x[0] for x in stored.coords]) / l centerY = sum([x[1] for x in stored.coords]) / l centerZ = sum([x[2] for x in stored.coords]) / l return cgoCircle(centerX, centerY, centerZ, r, cr, cg, cb, w)
[docs] def draw_dist(x1, y1, z1, x2, y2, z2): """ draw_dist(54.729, 28.9375, 41.421, 55.342, 35.3605, 42.745) https://sourceforge.net/p/pymol/mailman/message/25795427/ """ cmd.pseudoatom('pt1', pos=[x1, y1, z1]) cmd.pseudoatom('pt2', pos=[x2, y2, z2]) cmd.distance('pt1-pt2', 'pt1', 'pt2')
[docs] def draw_dists(interactions): # l=([1,2], [3,4]) for i in interactions: a = "////" + str(i[0]) + "/C2" b = "////" + str(i[1]) + "/C2" print(i[0], i[1], cmd.distance('d' + str(i[0]) + '-' + str(i[1]), "(" + a + ")", "(" + b + ")")) # mode, 4))
[docs] def draw_vector(x1, y1, z1, x2, y2, z2): """https://pymolwiki.org/index.php/CGOCylinder""" radius = 0.1 r1, g1, b1 = 0, 0, 1 # color (blue) r2, g2, b2 = 1, 0, 0 # color (red) cmd.load_cgo([9.0, x1, y1, z1, x2, y2, z2, radius, r1, g1, b1, r2, g2, b2], "vector")
try: import pymol from pymol.cgo import * except: print('PyMOL (Python library is missing') else: cmd.extend("draw_vector", draw_vector) cmd.extend("draw_dist", draw_dist) cmd.extend("draw_circle", draw_circle) cmd.extend("draw_circle_selection", draw_circle_selection) cmd.extend('draw_dists', draw_dists)