Skip to main content

ga_trial_pdf_jade

Generate a PDF report from a template.

Module

Functions

generate_pdf

def generate_pdf(    file_name: Union[str, os.PathLike],    report_info: AltrisRecordInfo,    scans: Union[AltrisScan, list[AltrisScan]],    metrics: Union[GAMetrics, list[GAMetrics]],    total_ga_area_lower_bound: float = 2.5,    total_ga_area_upper_bound: float = 17.5,    task_id: Optional[str] = None,)> None:

Generates a PDF report.

Arguments

  • file_name: The name of the file to save the report to.
  • report_info: The report info.
  • scans: The scans.
  • metrics: The GA metrics.
  • total_ga_area_lower_bound: The lower bound for the GA area. This is used to generate the slider. Defaults to 2.5.
  • total_ga_area_upper_bound: The upper bound for the GA area. This is used to generate the slider. Defaults to 17.5.
  • task_id: The task ID. Defaults to None.

Classes

AltrisRecordInfo

class AltrisRecordInfo(    text_fields: list[tuple[str, str]], heading: Optional[str] = 'GA OCT REPORT',):

Patient/scan information for the report.

Arguments

  • text_fields: A list of tuples of heading and value for the pdf top table.
  • heading: The heading for the pdf. Defaults to None.

Variables

  • static heading : Optional[str]
  • static text_fields : list[tuple[str, str]]

AltrisScan

class AltrisScan(    bscan_image: Union[str, os.PathLike, Image],    bscan_idx: int,    bscan_total: int,    bscan_w_mask: Union[str, os.PathLike, Image],    legend2color: dict[str, tuple[int, int, int]],    laterality: Optional[str] = None,    bscan_en_face: Optional[Union[str, os.PathLike, Image]] = None,):

Scan information for the report.

Arguments

  • name: Name of the scan.
  • en_face_image_path: Path to the en-face image.
  • bscan_image_path: Path to the B-scan image. This should be the bscan that corresponds to the location of the fovea.

Variables

  • static bscan_en_face : Union[str, os.PathLike, PIL.Image.Image, ForwardRef(None)]
  • static bscan_idx : int
  • static bscan_image : Union[str, os.PathLike, PIL.Image.Image]
  • static bscan_total : int
  • static bscan_w_mask : Union[str, os.PathLike, PIL.Image.Image]
  • static laterality : Optional[str]
  • static legend2color : dict[str, tuple[int, int, int]]

ReportJade

class ReportJade(    record_info: AltrisRecordInfo,    scan: Union[AltrisScan, list[AltrisScan]],    metrics: Union[GAMetrics, list[GAMetrics]],    total_ga_area_lower_bound: float = 2.5,    total_ga_area_upper_bound: float = 17.5,    task_id: Optional[str] = None,    **kwargs: Any,):

Generate a PDF report from a template.

Ancestors

  • fpdf.fpdf.FPDF
  • fpdf.graphics_state.GraphicsStateMixin
  • fpdf.text_region.TextRegionMixin

Methods


def footer(self)> None:

Adds the footer to the report.

Adds 'Bitfount' and the page number to every report. This is called automatically by the FPDF class.

generate

def generate(self)> None:

Generates the report.

This should be called by the user.

def header(self)> None:

Adds the header to the report.

Adds the Bitfount logo to the top right of every page. This is called automatically by the FPDF class.