001/* 002 * BioJava development code 003 * 004 * This code may be freely distributed and modified under the 005 * terms of the GNU Lesser General Public Licence. This should 006 * be distributed with the code. If you do not have a copy, 007 * see: 008 * 009 * http://www.gnu.org/copyleft/lesser.html 010 * 011 * Copyright for this code is held jointly by the individual 012 * authors. These should be listed in @author doc comments. 013 * 014 * For more information on the BioJava project and its aims, 015 * or to join the biojava-l mailing list, visit the home page 016 * at: 017 * 018 * http://www.biojava.org/ 019 * 020 */ 021package org.biojava.nbio.survival.kaplanmeier.figure; 022 023import org.biojava.nbio.survival.cox.StrataInfo; 024import org.biojava.nbio.survival.cox.SurvFitInfo; 025 026import javax.swing.*; 027import java.awt.*; 028import java.util.ArrayList; 029import java.util.Collections; 030import java.util.LinkedHashMap; 031 032/** 033 * 034 * @author Scooter Willis 035 */ 036public class NumbersAtRiskPanel extends JPanel { 037 038 private static final long serialVersionUID = 1L; 039 040 KaplanMeierFigure kmf = null; 041 Double timePercentage = .20; 042 043 public NumbersAtRiskPanel() { 044 this.setPreferredSize(new Dimension(400,100)); 045 this.setSize(400, 100); 046 } 047 048 /** 049 * Pick up needed info and details from the KM Figure 050 * @param kmf 051 */ 052 public void setKaplanMeierFigure(KaplanMeierFigure kmf) { 053 this.kmf = kmf; 054 055 int numRows = kmf.getSurvivalFitInfo().getStrataInfoHashMap().size(); 056 int height = (numRows + 1) * getFontMetrics(getFont()).getHeight(); 057 int width = kmf.getWidth(); 058 setPreferredSize(new Dimension(width,height)); 059 this.setSize(width, height); 060 061 } 062 063 private void paintTable(Graphics g) { 064 065 if(kmf == null) 066 return; 067 KMFigureInfo kmfi = kmf.getKMFigureInfo(); 068 Graphics2D g2 = (Graphics2D) g; 069 g2.setStroke(kmfi.kmStroke); 070 SurvFitInfo sfi = kmf.getSurvivalFitInfo(); 071 072 LinkedHashMap<String, StrataInfo> sfiHashMap = new LinkedHashMap<>(); 073 if(sfi.isWeighted()){ 074 sfiHashMap = sfi.getUnweightedStrataInfoHashMap(); 075 }else{ 076 sfiHashMap = sfi.getStrataInfoHashMap(); 077 } 078 079 if(sfiHashMap.size() == 0) 080 return; 081 //int height = this.getHeight(); 082 083 int row = 0; 084 int left = kmf.getLeft(); 085 //int right = kmf.getRight(); 086 //int width = right - left; 087 Font f = g2.getFont(); 088 Font nf = new Font(f.getName(), Font.BOLD, f.getSize()); 089 g2.setFont(nf); 090 FontMetrics fm = getFontMetrics(nf); 091 int index = 0; 092 int fontHeight = getFontMetrics(getFont()).getHeight(); 093 int increment = fontHeight; 094 ArrayList<Double> xaxisTimeValues = kmf.getxAxisTimeValues(); 095 ArrayList<Integer> xAxisTimeCoordinates = kmf.getxAxisTimeCoordinates(); 096 097 ArrayList<String> labels = new ArrayList<>(sfiHashMap.keySet()); 098 Collections.sort(labels); 099 100 for (String group : labels) { 101 row = row + increment; 102 g2.setColor(kmfi.getColor(index)); 103 index++; 104 g2.drawLine(15, row - fontHeight/2, left - 5, row - fontHeight/2); 105 g2.setColor(Color.BLACK); 106 StrataInfo si = sfiHashMap.get(group); 107 if("[APOBEC1 Transhera Observation Arm]".equals(kmf.title.toString())){ 108 //int dummy = 1; 109 } 110// System.out.println(kmf.title + " Group " + group); 111// System.out.println(si); 112 for(int i = 0; i < xaxisTimeValues.size(); i++){ 113 Double time = xaxisTimeValues.get(i); 114 int xvalue = xAxisTimeCoordinates.get(i); 115 Double value = si.getNearestAtRisk(time); 116 String nrisk = ""; 117 if(value == null){ 118 nrisk = ""; 119 }else{ 120 nrisk = String.valueOf(value.intValue()); 121 } 122 if(time == 0.0){ 123 g2.drawString(nrisk , xvalue, row); 124 }else{ 125 int w = fm.stringWidth(nrisk ); 126 g2.drawString(nrisk , xvalue - w/2, row); 127 } 128 } 129 130 } 131 } 132 133 @Override 134 protected void paintComponent(Graphics g) { 135 136 super.paintComponent(g); //To change body of generated methods, choose Tools | Templates. 137 g.setColor(Color.white); 138 g.fillRect(0, 0, this.getWidth(), this.getHeight()); 139 140 this.paintTable(g); 141 } 142 143 /** 144 * @param args the command line arguments 145 */ 146 public static void main(String[] args) { 147 // TODO code application logic here 148 } 149}