mirror of
https://github.com/moses-smt/mosesdecoder.git
synced 2025-01-07 12:10:36 +03:00
f34b37bad3
git-svn-id: https://mosesdecoder.svn.sourceforge.net/svnroot/mosesdecoder/trunk@3514 1f5c12ca-751b-0410-a591-d2e778427230
97 lines
2.7 KiB
JavaScript
97 lines
2.7 KiB
JavaScript
var nodeIn = [];
|
|
var nodeOut = [];
|
|
var nodeChildren = [];
|
|
var max_depth = [];
|
|
var span_count_in = [];
|
|
var span_count_out = [];
|
|
var current_depth = -1;
|
|
|
|
function alignIn( sentence, word, depth ) {
|
|
if (current_depth < depth) {
|
|
current_depth = depth;
|
|
}
|
|
else { return; }
|
|
|
|
var id = 0;
|
|
for(var i=1;i<nodeIn[sentence].size();i++ ) {
|
|
if (nodeIn[sentence][i].start <= word && word <= nodeIn[sentence][i].end && nodeIn[sentence][i].depth <= depth) {
|
|
id = i;
|
|
}
|
|
}
|
|
|
|
highlightNode( sentence, id );
|
|
}
|
|
|
|
function alignOut( sentence, word, depth ) {
|
|
if (current_depth < depth) {
|
|
current_depth = depth;
|
|
}
|
|
else { return; }
|
|
var id = 0;
|
|
for(var i=1;i<nodeOut[sentence].size();i++ ) {
|
|
if (nodeOut[sentence][i].start <= word && word <= nodeOut[sentence][i].end && nodeOut[sentence][i].depth <= depth) {
|
|
id = i;
|
|
}
|
|
}
|
|
|
|
highlightNode( sentence, id );
|
|
}
|
|
|
|
function unAlign( sentence ) {
|
|
if (current_depth == -1) { return; }
|
|
current_depth = -1;
|
|
lowlightAllNodes( sentence );
|
|
}
|
|
|
|
function highlightNode( sentence, id ) {
|
|
lowlightAllNodes( sentence );
|
|
highlightSingleNode( sentence, id, 'yellow' );
|
|
for(var i=0; i<nodeChildren[sentence][id].size(); i++) {
|
|
var childId = nodeChildren[sentence][id][i];
|
|
highlightSingleNode( sentence, childId, '#ffffa0');
|
|
for(var j=0; j<nodeChildren[sentence][childId].size(); j++) {
|
|
highlightSingleNode( sentence, nodeChildren[sentence][childId][j], '#ffffe0');
|
|
}
|
|
}
|
|
}
|
|
|
|
function highlightSingleNode( sentence, id, color ) {
|
|
for(var i=nodeIn[sentence][id].start;i<=nodeIn[sentence][id].end;i++) {
|
|
for(var j=nodeIn[sentence][id].depth;j<=max_depth[sentence];j++) {
|
|
var item = "in-" + sentence + "-" + i + "-" + j;
|
|
if ($(item) != null) {
|
|
$(item).setStyle({ backgroundColor: color, borderColor: 'red' });
|
|
}
|
|
}
|
|
}
|
|
//$("debug").innerHTML = "highlight: "+id+", of "+nodeOut[sentence].size()+"<br>";
|
|
for(var i=nodeOut[sentence][id].start;i<=nodeOut[sentence][id].end;i++) {
|
|
for(var j=nodeOut[sentence][id].depth;j<=max_depth[sentence];j++) {
|
|
var item = "out-" + sentence + "-" + i + "-" + j;
|
|
//$("debug").innerHTML += item;
|
|
if ($(item) != null) {
|
|
$(item).setStyle({ backgroundColor: color, borderColor: 'red' });
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function lowlightAllNodes( sentence ) {
|
|
for(var i=0;i<span_count_in[sentence];i++) {
|
|
for(var j=0;j<=max_depth[sentence];j++) {
|
|
var item = "in-" + sentence + "-" + i + "-" + j;
|
|
if ($(item) != null) {
|
|
$(item).setStyle({ backgroundColor: 'white', borderColor: 'black' });
|
|
}
|
|
}
|
|
}
|
|
for(var i=0;i<span_count_out[sentence];i++) {
|
|
for(var j=0;j<=max_depth[sentence];j++) {
|
|
var item = "out-" + sentence + "-" + i + "-" + j;
|
|
if ($(item) != null) {
|
|
$(item).setStyle({ backgroundColor: 'white', borderColor: 'black' });
|
|
}
|
|
}
|
|
}
|
|
}
|