Kurz: Vývoj vizuálu kruhové karty Power BI

V tomto kurzu vytvoříte vizuál Power BI s názvem kruhová karta, která zobrazí formátovanou hodnotu míry uvnitř kruhu. Vizuál karty s kruhem podporuje přizpůsobení barvy výplně a tloušťky obrysu.

V tomto kurzu se naučíte:

  • Vytvořte vývojový projekt pro vizuál.
  • Vývoj vizuálu pomocí vizuálních prvků D3
  • Nakonfigurujte vizuál tak, aby zpracovával data.
  • Nakonfigurujte vizuál tak, aby se přizpůsobil změnám velikosti.
  • Nakonfigurujte pro vizuál adaptivní nastavení barev a ohraničení.

Poznámka:

Úplný zdrojový kód tohoto vizuálu najdete ve vizuálu Power BI s kruhovou kartou.

Požadavky

Než začnete s vývojem vizuálu Power BI, ověřte, že máte všechno uvedené v této části.

Vytvoření vývojového projektu

V této části vytvoříte projekt pro vizuál karty s kruhem.

Poznámka:

V tomto kurzu se Visual Studio Code (VS Code) používá k vývoji vizuálu Power BI.

  1. Ve VS Code otevřete nový terminál a přejděte do složky, ve které chcete projekt vytvořit.

  2. V terminálu PowerShellu zadejte následující příkaz:

    pbiviz new CircleCard
    
  3. Otevřete složku CircleCard v průzkumníku VS Code. (Otevřená složka souboru>).

    Snímek obrazovky s oknem VS Code otevřeným ve složce karty s kruhem

    Podrobné vysvětlení funkce jednotlivých souborů najdete v tématu Struktura projektu vizuálu Power BI.

  4. Zkontrolujte okno terminálu a ověřte, že jste v adresáři circleCard. Nainstalujte závislosti vizuálních nástrojů Power BI.

    npm install
    

    Tip

    Pokud chcete zjistit, které závislosti byly ve vizuálu nainstalované, zkontrolujte soubor package.json .

  5. Spusťte vizuál karty s kruhem.

    pbiviz start
    

    Vizuál je teď spuštěný při hostování na vašem počítači.

    Důležité

    Nezavírejte okno PowerShellu až do konce kurzu. Pokud chcete zastavit spuštění vizuálu, zadejte Ctrl+C a pokud se zobrazí výzva k ukončení dávkové úlohy, zadejte Y a pak Enter.

Zobrazení vizuálu v služba Power BI

K otestování vizuálu v služba Power BI použijeme sestavu analýzy prodeje v USA. Tuto sestavu si můžete stáhnout a nahrát ji do služba Power BI.

K otestování vizuálu můžete použít také vlastní sestavu.

Poznámka:

Než budete pokračovat, ověřte, že jste povolili nastavení vývojáře vizuálů.

  1. Přihlaste se k PowerBI.com a otevřete sestavu analýzy prodeje v USA.

  2. Vyberte položku Upravit.

    Snímek obrazovky s možností úprav ve službě Power BI

  3. Vytvořte novou stránku pro testování kliknutím na tlačítko Nová stránka v dolní části rozhraní služba Power BI.

    Snímek obrazovky s tlačítkem nová stránka ve službě Power BI

  4. V podokně Vizualizace vyberte vývojářský vizuál.

    Snímek obrazovky s vizuálem vývojáře v podokně vizualizace

    Tento vizuál představuje vlastní vizuál, který používáte v počítači. Je dostupná jenom v případech, kdy je povolené nastavení ladění vlastního vizuálu.

  5. Ověřte, že byl vizuál přidán na plátno sestavy.

    Snímek obrazovky s novým vizuálem přidaným do sestavy

    Jedná se o jednoduchý vizuál, který zobrazuje počet, kolikrát byla volána metoda aktualizace. V této fázi vizuál nenačte žádná data.

    Poznámka:

    Pokud vizuál zobrazí chybovou zprávu o připojení, otevřete v prohlížeči novou kartu, přejděte na https://localhost:8080/assetsadresu a autorizujete prohlížeč tak, aby používal tuto adresu.

    Snímek obrazovky s novým vizuálem zobrazujícím chybu připojení

  6. Když je nový vizuál vybraný, přejděte do podokna Pole , rozbalte položku Sales (Prodej) a vyberte Quantity (Množství).

    Snímek obrazovky s polem Množství služby Power BI v tabulce prodejů v sestavě analýzy prodeje V USA

  7. Pokud chcete otestovat, jak vizuál reaguje, změňte jeho velikost a všimněte si, že se při každé změně velikosti vizuálu zvýší hodnota počtu aktualizací.

    Snímek obrazovky s novým vizuálem zobrazující jiný počet aktualizací po změně velikosti

Přidání vizuálních prvků a textu

V této části se dozvíte, jak vizuál převést na kruh a nastavit ho jako zobrazovaný text.

Úprava souboru vizuálů

Nastavte soubor visual.ts .

Tip

Pokud chcete zlepšit čitelnost, doporučujeme dokument naformátovat při každém kopírování fragmentů kódu do projektu. Klikněte pravým tlačítkem na libovolné místo v editoru VS Code a vyberte Formát dokumentu (nebo zadejte Alt+Shift+F).

  1. V editoru VS Code v podokně Průzkumník rozbalte složku src a vyberte soubor visual.ts.

    Snímek obrazovky s přístupem k souboru visual.ts v kódu V S

  2. Odeberte veškerý kód pod komentářem licence MIT.

    Důležité

    Všimněte si komentářů v horní části souboru visual.ts . Oprávnění k používání balíčků vizuálů Power BI je uděleno bezplatně podle podmínek licence Mit (Massachusetts Institute of Technology). V rámci smlouvy musíte nechat komentáře v horní části souboru.

  3. Importujte potřebné knihovny a moduly a definujte výběr typu pro knihovnu d3:

    "use strict";
    
    import "./../style/visual.less";
    import powerbi from "powerbi-visuals-api";
    import VisualConstructorOptions = powerbi.extensibility.visual.VisualConstructorOptions;
    import VisualUpdateOptions = powerbi.extensibility.visual.VisualUpdateOptions;
    import IVisual = powerbi.extensibility.visual.IVisual;
    import DataView = powerbi.DataView;
    import IVisualHost = powerbi.extensibility.IVisualHost;
    import * as d3 from "d3";
    type Selection<T extends d3.BaseType> = d3.Selection<T, any, any, any>;
    

    Poznámka:

    Pokud se knihovna D3 JavaScript nenainstalovala jako součást instalace, nainstalujte ji teď. V PowerShellu spusťte příkaz npm i d3@latest --save

    Všimněte si, že mezi importovanými položkami jsou:

    • IVisualHost – kolekce vlastností a služeb používaných k interakci s hostitelem vizuálu (Power BI).
    • Knihovna D3 – JavaScriptová knihovna pro vytváření dokumentů řízených daty
  4. Pod importy vytvořte prázdnou třídu vizuálu . Třída vizuálu implementuje rozhraní IVisual, kde začínají všechny vizuály:

    export class Visual implements IVisual {
    
    }
    

    Informace o tom, co jde do třídy vizuálu, najdete v tématu Rozhraní Visual API. V dalších třech krocích definujeme tuto třídu.

  5. Na začátek třídy vizuálupřidejte privátní metody na úrovni třídy třídy:

    private host: IVisualHost;
    private svg: Selection<SVGElement>;
    private container: Selection<SVGElement>;
    private circle: Selection<SVGElement>;
    private textValue: Selection<SVGElement>;
    private textLabel: Selection<SVGElement>;
    

    Všimněte si, že některé z těchto privátních metod používají typ Výběru.

  6. Definujte kruh a textové prvky v metodě konstruktoru. Tato metoda je volána při vytvoření instance vizuálu. SvG (Scalable Vector Graphics) D3 umožňuje vytvářet tři obrazce: kruh a dva textové prvky:

    constructor(options: VisualConstructorOptions) {
        this.svg = d3.select(options.element)
            .append('svg')
            .classed('circleCard', true);
        this.container = this.svg.append("g")
            .classed('container', true);
        this.circle = this.container.append("circle")
            .classed('circle', true);
        this.textValue = this.container.append("text")
            .classed("textValue", true);
        this.textLabel = this.container.append("text")
            .classed("textLabel", true);
    }
    
  7. Definujte šířku a výšku v metodě aktualizace. Tato metoda se volá při každé změně dat nebo hostitelského prostředí, například nové hodnoty nebo změny velikosti.

    public update(options: VisualUpdateOptions) {
        let width: number = options.viewport.width;
        let height: number = options.viewport.height;
        this.svg.attr("width", width);
        this.svg.attr("height", height);
        let radius: number = Math.min(width, height) / 2.2;
        this.circle
            .style("fill", "white")
            .style("fill-opacity", 0.5)
            .style("stroke", "black")
            .style("stroke-width", 2)
            .attr("r", radius)
            .attr("cx", width / 2)
            .attr("cy", height / 2);
        let fontSizeValue: number = Math.min(width, height) / 5;
        this.textValue
            .text("Value")
            .attr("x", "50%")
            .attr("y", "50%")
            .attr("dy", "0.35em")
            .attr("text-anchor", "middle")
            .style("font-size", fontSizeValue + "px");
        let fontSizeLabel: number = fontSizeValue / 4;
        this.textLabel
            .text("Label")
            .attr("x", "50%")
            .attr("y", height / 2)
            .attr("dy", fontSizeValue / 1.2)
            .attr("text-anchor", "middle")
            .style("font-size", fontSizeLabel + "px");
    }
    
  8. Uložte soubor visual.ts.

(Volitelné) Kontrola kódu v souboru vizuálů

Ověřte, že konečný kód v souboru visual.ts vypadá takto:

/*
*  Power BI Visual CLI
*
*  Copyright (c) Microsoft Corporation
*  All rights reserved.
*  MIT License
*
*  Permission is hereby granted, free of charge, to any person obtaining a copy
*  of this software and associated documentation files (the ""Software""), to deal
*  in the Software without restriction, including without limitation the rights
*  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
*  copies of the Software, and to permit persons to whom the Software is
*  furnished to do so, subject to the following conditions:
*
*  The above copyright notice and this permission notice shall be included in
*  all copies or substantial portions of the Software.
*
*  THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
*  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
*  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
*  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
*  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
*  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
*  THE SOFTWARE.
*/
"use strict";

import "./../style/visual.less";
import powerbi from "powerbi-visuals-api";
import VisualConstructorOptions = powerbi.extensibility.visual.VisualConstructorOptions;
import VisualUpdateOptions = powerbi.extensibility.visual.VisualUpdateOptions;
import IVisual = powerbi.extensibility.visual.IVisual;
import DataView = powerbi.DataView;
import IVisualHost = powerbi.extensibility.IVisualHost;
import * as d3 from "d3";
type Selection<T extends d3.BaseType> = d3.Selection<T, any, any, any>;

export class Visual implements IVisual {
    private host: IVisualHost;
    private svg: Selection<SVGElement>;
    private container: Selection<SVGElement>;
    private circle: Selection<SVGElement>;
    private textValue: Selection<SVGElement>;
    private textLabel: Selection<SVGElement>;
    
    constructor(options: VisualConstructorOptions) {
        this.svg = d3.select(options.element)
            .append('svg')
            .classed('circleCard', true);
        this.container = this.svg.append("g")
            .classed('container', true);
        this.circle = this.container.append("circle")
            .classed('circle', true);
        this.textValue = this.container.append("text")
            .classed("textValue", true);
        this.textLabel = this.container.append("text")
            .classed("textLabel", true);
    }
    
    public update(options: VisualUpdateOptions) {
        let width: number = options.viewport.width;
        let height: number = options.viewport.height;
        this.svg.attr("width", width);
        this.svg.attr("height", height);
        let radius: number = Math.min(width, height) / 2.2;
        this.circle
            .style("fill", "white")
            .style("fill-opacity", 0.5)
            .style("stroke", "black")
            .style("stroke-width", 2)
            .attr("r", radius)
            .attr("cx", width / 2)
            .attr("cy", height / 2);
        let fontSizeValue: number = Math.min(width, height) / 5;
        this.textValue
            .text("Value")
            .attr("x", "50%")
            .attr("y", "50%")
            .attr("dy", "0.35em")
            .attr("text-anchor", "middle")
            .style("font-size", fontSizeValue + "px");
        let fontSizeLabel: number = fontSizeValue / 4;
        this.textLabel
            .text("Label")
            .attr("x", "50%")
            .attr("y", height / 2)
            .attr("dy", fontSizeValue / 1.2)
            .attr("text-anchor", "middle")
            .style("font-size", fontSizeLabel + "px");
    }
}

Úprava souboru schopností

Vizuál karty s kruhem je jednoduchý vizuál, který nevytvoří žádné objekty v podokně Formát. Proto můžete bezpečně odebrat oddíl objektů souboru.

  1. Otevřete projekt ve VS Code (>Soubor otevřít složku).

  2. Vyberte soubor capabilities.json.

    Snímek obrazovky s přístupem k souboru capabilities.json v kódu V S

  3. Odeberte celé pole objektů .
    Nenechávejte žádné prázdné řádky mezi dataRoles a dataViewMappings.

  4. Uložte soubor capabilities.json.

Restartování vizuálu karty s kruhem

Zastavte spuštění vizuálu a restartujte ho.

  1. V okně PowerShellu, ve kterém jste vizuál spustili, zadejte Ctrl+C. Pokud se zobrazí výzva k ukončení dávkové úlohy, zadejte Y a pak Enter.

  2. V PowerShellu spusťte vizuál znovu.

    pbiviz start
    

Testování vizuálu s přidanými elementy

Ověřte, že vizuál zobrazuje nově přidané prvky.

  1. V služba Power BI otevřete sestavu Analýzy prodeje v USA v Power BI. Pokud k vývoji vizuálu karty s kruhem používáte jinou sestavu, přejděte na tuto sestavu.

  2. Přetáhněte hodnotu do pole Míra a ujistěte se, že je vizuál tvarovaný jako kruh.

    Snímek obrazovky s vizuálem karty s kruhem ve tvaru kruhu

    Pokud vizuál nic nezobrazuje, přetáhněte z podokna Pole pole Množství do vývojářského vizuálu.

  3. Změňte velikost vizuálu.

    Všimněte si, že měřítko kruhu a textu tak, aby odpovídaly rozměrům vizuálu. Metoda aktualizace se volá při změně velikosti vizuálu a v důsledku toho se prvky vizuálu znovu škálují.

Povolení automatického opětovného načítání

Pomocí tohoto nastavení se ujistěte, že se vizuál při každém uložení změn projektu automaticky znovu načte.

  1. Přejděte do sestavy Power BI US Sales Analysis (nebo do projektu, který obsahuje vizuál karty s kruhem).

  2. Vyberte vizuál karty s kruhem.

  3. Na plovoucím panelu nástrojů vyberte Přepnout automatické opětovné načítání.

    Snímek obrazovky s kliknutím na možnost automatického opětovného načítání přepínače na plovoucím panelu nástrojů vizuálu karty s kruhem

Získání vizuálu pro zpracování dat

V této části definujete role dat a mapování zobrazení dat. Vizuál také upravíte tak, aby zobrazoval název zobrazované hodnoty.

Konfigurace souboru možností

Upravte soubor capabilities.json tak, aby definoval roli dat, objekty a mapování zobrazení dat.

  • Definování role dat

    Definujte pole dataRoles s jednou datovou rolí míry typu. Tato datová role se nazývá míra a zobrazuje se jako míra. Umožňuje předat pole míry nebo pole sečtené.

    1. Otevřete soubor capabilities.json v editoru VS Code.

    2. Odeberte veškerý obsah uvnitř pole dataRoles .

    3. Do pole dataRoles vložte následující kód.

      {
          "displayName": "Measure",
          "name": "measure",
          "kind": "Measure"
      }
      
    4. Uložte soubor capabilities.json.

  • Definování mapování zobrazení dat

    Definujte pole s názvem míra v poli dataViewMappings . Toto pole lze předat roli dat.

    1. Otevřete soubor capabilities.json v editoru VS Code.

    2. Odeberte veškerý obsah v poli dataViewMappings .

    3. Do pole dataViewMappings vložte následující kód.

      {
          "conditions": [
              { "measure": { "max": 1 } }
          ],
          "single": {
              "role": "measure"
          }
      }
      
    4. Uložte soubor capabilities.json.

Ověřte, že váš soubor capabilities.json vypadá takto:

{
    "dataRoles": [
        {
            "displayName": "Measure",
            "name": "measure",
            "kind": "Measure"
        }
    ],
    "dataViewMappings": [
        {
            "conditions": [
                { "measure": { "max": 1 } }
            ],
            "single": {
                "role": "measure"
            }
        }
    ],
    "privileges": []
}

(Volitelné) Kontrola změn kódu souboru schopností

Ověřte, že vizuál karty s kruhem zobrazuje pole míry , a zkontrolujte provedené změny pomocí možnosti Zobrazit zobrazení dat.

  1. V služba Power BI otevřete sestavu Analýzy prodeje v USA v Power BI. Pokud k vývoji vizuálu karty s kruhem používáte jinou sestavu, přejděte na tuto sestavu.

  2. Všimněte si, že vizuál karty s kruhem je teď možné nakonfigurovat pomocí pole s názvem Míra. Prvky můžete přetáhnout z podokna Pole do pole Míra .

    Snímek obrazovky s mírou kruhové karty v podokně vizualizace služba Power BI

    Poznámka:

    Projekt vizuálu zatím neobsahuje logiku vazby dat.

  3. Na plovoucím panelu nástrojů vyberte Zobrazit zobrazení dat.

    Snímek obrazovky s tlačítkem zobrazit zobrazení dat umístěným na plovoucím panelu nástrojů karty s kruhem

  4. Výběrem tří tečk rozbalte zobrazení a výběrem jedné hodnoty zobrazte hodnotu.

    Snímek obrazovky s obrázkem hodnoty, který se zobrazuje na kartě s kruhem, zobrazuje možnost dataview

  5. Rozbalte metadata, pak pole sloupců a zkontrolujte hodnoty formátu a displayName .

    Snímek obrazovky s hodnotami formátu a zobrazovaného názvu zobrazenými na kartě s kruhem zobrazující možnost dataview

  6. Pokud chcete přepnout zpět na vizuál, vyberte na panelu nástrojů nad vizuálem možnost Zobrazit zobrazení dat.

Konfigurace vizuálu pro využívání dat

Zatím se vizuál vykresluje, ale nezobrazuje žádná data. V této části provedete změny v souboru visual.ts tak, aby vizuál karty s kruhem mohl využívat data.

  1. Otevřete soubor visual.ts v editoru VS Code.

  2. V metodě aktualizace:

    • Jako první příkaz přidejte následující příkaz. Příkaz přiřadí dataView proměnné pro snadný přístup a deklaruje proměnnou odkaz na objekt dataView .

      let dataView: DataView = options.dataViews[0];
      
    • Nahraďte .text("Value") tímto řádkem kódu:

      .text(<string>dataView.single.value)
      
    • Nahraďte .text("Label") tímto řádkem kódu:

      .text(dataView.metadata.columns[0].displayName)
      
  3. Uložte soubor visual.ts.

  4. Prohlédněte si vizuál v služba Power BI.

Vizuál teď zobrazuje název a hodnotu vybraného datového pole.

Snímek obrazovky s vizuálem karty s kruhem zobrazující hodnotu množství

Právě jste vytvořili funkční vizuál Power BI. Můžete k němu přidat možnosti formátování nebo ho můžete zabalit tak, jak je to pro okamžité použití.