當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Tree::Parse方法代碼示例

本文整理匯總了PHP中Tree::Parse方法的典型用法代碼示例。如果您正苦於以下問題:PHP Tree::Parse方法的具體用法?PHP Tree::Parse怎麽用?PHP Tree::Parse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Tree的用法示例。


在下文中一共展示了Tree::Parse方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: tree2kml

function tree2kml($obj, $default_labels = 'taxa')
{
    $t = new Tree();
    $t->Parse($obj->tree->newick);
    $t->BuildWeights($t->GetRoot());
    // compute KML coordinates
    $attr = array();
    $td = new KmlTreeDrawer($t, $attr);
    $td->CalcCoordinates();
    // raw labels (OTUs)
    //	$port->StartGroup('otu', (('otu' == $default_labels) || !isset($obj->translations)) );
    $kml = '';
    $kml .= "<?xml version =\"1.0\" encoding=\"UTF-8\"?>\n";
    $kml .= "<kml xmlns=\"http://earth.google.com/kml/2.1\">\n";
    $kml .= "<Document>\n";
    $kml .= "<Style id=\"treeLine\">\n";
    $kml .= "<LineStyle><color>7fffffff</color><width>2</width></LineStyle>\n";
    $kml .= "</Style>\n";
    $kml .= "<Style id=\"whiteBall\">\n";
    $kml .= "<IconStyle>\n";
    $kml .= "<Icon>\n";
    $kml .= "<href>http://iphylo.org/~rpage/phyloinformatics/images/whiteBall.png</href>\n";
    $kml .= "</Icon>\n";
    $kml .= "</IconStyle>\n";
    $kml .= "<LineStyle>\n";
    $kml .= "<width>2</width>\n";
    $kml .= "</LineStyle>\n";
    $kml .= "</Style>\n";
    $td->Draw(null);
    $kml .= $td->kml;
    $kml .= "<Folder>\n";
    $kml .= "<name>Labels</name>\n";
    // labels
    $ni = new NodeIterator($t->getRoot());
    $q = $ni->Begin();
    while ($q != NULL) {
        if ($q->IsLeaf()) {
            $kml .= "<Placemark>\n";
            $kml .= "<name>" . $q->Getlabel() . "</name>\n";
            $kml .= "<styleUrl>#whiteBall</styleUrl>\n";
            $kml .= "<Point>\n";
            $kml .= "<altitudeMode>absolute</altitudeMode>\n";
            $kml .= "<extrude>1</extrude>\n";
            $kml .= "<coordinates>\n";
            $kml .= $q->GetAttribute('long') . "," . $q->GetAttribute('lat') . "," . $q->GetAttribute('altitude') . "\n";
            $kml .= "</coordinates>\n";
            $kml .= "</Point>\n";
            $kml .= "</Placemark>\n";
        }
        $q = $ni->Next();
    }
    $kml .= "</Folder>\n";
    $kml .= "</Document>\n";
    $kml .= "</kml>\n";
    echo $kml;
}
開發者ID:rdmpage,項目名稱:phyloinformatics,代碼行數:56,代碼來源:tkml.php

示例2: main

function main()
{
    global $matching_path;
    $have_tree = false;
    $have_taxa = false;
    $have_table = false;
    $newick = '';
    if (isset($_POST['tree'])) {
        $obj = parse_nexus(stripcslashes($_POST['tree']));
        $taxa = get_taxa_from_tree($obj);
        $newick = $obj->tree->newick;
        //echo $newick;
        //print_r($obj);
        $t = new Tree();
        $t->Parse($newick);
        $ni = new NodeIterator($t->getRoot());
        $q = $ni->Begin();
        while ($q != NULL) {
            if ($q->IsLeaf()) {
                if (isset($obj->translations->translate)) {
                    $q->SetLabel($obj->translations->translate[$q->GetLabel()]);
                }
            }
            $q = $ni->Next();
        }
        $newick = $t->WriteNewick();
        //echo $newick;
        $have_tree = true;
    }
    if (isset($_POST['taxa'])) {
        $have_taxa = true;
    }
    if (isset($_POST['table'])) {
        $table = $_POST['table'];
        $have_table = true;
    }
    if (isset($_POST['newick'])) {
        $newick = $_POST['newick'];
    }
    if ($have_tree || $have_taxa) {
        if ($have_table) {
            // get taxa
            $taxa = explode("\n", stripcslashes($_POST['taxa']));
            $n = count($taxa);
            for ($i = 0; $i < $n; $i++) {
                $taxa[$i] = trim($taxa[$i]);
            }
            // get table data
            $table = stripcslashes($_POST['table']);
            // Interpret table automatically...
            // assume column one contains OTUs, and some other column(s) have lat and long
            $data = extract_table($table);
            //print_r($data);
            if (count($taxa) != count($data)) {
                echo '<html>
	<head>
	<meta charset="utf-8" />
			<style type="text/css" title="text/css">
			body { font-family:sans-serif;padding:20px; }
			</style>
	<title>Create KML tree - Error</title>
	</head>
	<body>
	<a href=".">Back</a>
	<h1>Error</h1>
	<p>The number of taxa in the tree (' . count($taxa) . ') does not match the number in the table (' . count($data) . ')</p>
	</body>
	</html>';
                exit;
            }
            $data_lookup_by_label = array();
            foreach ($data as $d) {
                $data_lookup_by_label[$d->label] = $d;
            }
            // show matching...
            /*
            echo '			<form method="post" action=".">
            	<table border="1">';
            	
            	echo '<tr><th>Taxa in tree</th><th>Taxa in table</th><th>Latitude</th><th>Longitude</th></tr>';
            	
            	$nrows = count($data);
            	for ($i=0;$i < $nrows; $i++)
            	{
            		echo '<tr>';
            		
            		echo '<td>' . $taxa[$i] . '</td>';
            		echo '<td>' . $data[$i]->label . '</td>';
            		echo '<td>' . $data[$i]->latlong['latitude'] . '</td>';
            		echo '<td>' . $data[$i]->latlong['longitude'] . '</td>';
            		echo '</td></tr>';
            	}					
            
            					
            	
            echo '</table>
            
            	
            	<input type="submit" value="Go"></input>
            </form>';
//.........這裏部分代碼省略.........
開發者ID:rdmpage,項目名稱:phyloinformatics,代碼行數:101,代碼來源:index.php

示例3: tree2svg

/**
 * @begin Draw tree and labels in SVG
 *
 * @param width Width (pixels) to draw tree + labels in
 * @param height
 * @param label_space Width (pixels) of space to draw leaf labels in
 * @param font_height Height of font to use to draw labels
 * @param default_labels Name of group of labels to show by default
 *
 */
function tree2svg($obj, $width = 400, $height = 400, $label_space = 150, $font_height = 10, $force_height = false, $default_labels = 'taxa')
{
    //----------------------------------------------------------------------------------------------
    $t = new Tree();
    $t->Parse($obj->tree->newick);
    $t->BuildWeights($t->GetRoot());
    $tree_width = $width - $label_space;
    if (!$force_height) {
        // adjust height to accomodate tree
        $height = $t->GetNumLeaves() * ($font_height + $font_height / 3);
        $inset = $font_height;
    } else {
        $inset = 0;
    }
    // Drawing properties
    $attr = array();
    $attr['inset'] = $inset;
    $attr['width'] = $tree_width;
    $attr['height'] = $height;
    $attr['font_height'] = $font_height;
    $attr['line_width'] = 1;
    // Don't draw labels (we do this afterwards)
    $attr['draw_leaf_labels'] = false;
    $attr['draw_internal_labels'] = false;
    $td = NULL;
    if ($t->HasBranchLengths()) {
        $td = new PhylogramTreeDrawer($t, $attr);
    } else {
        $td = new RectangleTreeDrawer($t, $attr);
    }
    $td->CalcCoordinates();
    if (!$force_height) {
        $port = new SVGPort('', $width, $td->max_height + $attr['font_height']);
    } else {
        $port = new SVGPort('', $width, $height + 2);
    }
    $port->StartGroup('tree');
    $td->Draw($port);
    $port->EndGroup();
    // labels
    if ($label_space > 0) {
        $ni = new NodeIterator($t->getRoot());
        // raw labels (OTUs)
        $port->StartGroup('otu', 'otu' == $default_labels || !isset($obj->translations));
        $q = $ni->Begin();
        while ($q != NULL) {
            if ($q->IsLeaf()) {
                $p0 = $q->GetAttribute('xy');
                $p0['x'] += $font_height / 3;
                $text = $q->Getlabel();
                $text = str_replace("_", " ", $text);
                $action = 'onclick="node_info(\'' . htmlentities($text) . '\');"';
                $port->DrawText($p0, $text, $action);
            }
            $q = $ni->Next();
        }
        $port->EndGroup();
        if ($obj->translations) {
            // Tree has a one or more translation tables
            foreach ($obj->translations as $k => $v) {
                // Draw labels as a separate group
                $port->StartGroup($k, $k == $default_labels ? true : false);
                $q = $ni->Begin();
                while ($q != NULL) {
                    if ($q->IsLeaf()) {
                        $p0 = $q->GetAttribute('xy');
                        $p0['x'] += $font_height / 3;
                        $label = $q->Getlabel();
                        if (is_array($v)) {
                            if (isset($v[$label])) {
                                $label = $v[$label];
                            } else {
                                // No translation for this OTU
                                $label = '[' . $label . ']';
                            }
                        } else {
                            if (isset($v->{$label})) {
                                $label = $v->{$label};
                            } else {
                                // No translation for this OTU
                                $label = '[' . $label . ']';
                            }
                        }
                        $action = 'onclick="node_info(\'' . $q->Getlabel() . '\');"';
                        $port->DrawText($p0, $label, $action);
                    }
                    $q = $ni->Next();
                }
                $port->EndGroup();
            }
//.........這裏部分代碼省略.........
開發者ID:rdmpage,項目名稱:phyloinformatics,代碼行數:101,代碼來源:tree2svg.php


注:本文中的Tree::Parse方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。