Flex - Dukungan Pencetakan
Flex menyediakan kelas khusus FlexPrintJob untuk mencetak objek fleksibel.
FlexPrintJob dapat digunakan untuk mencetak satu atau lebih objek Flex, seperti wadah Formulir atau VBox.
FlexPrintJob mencetak objek dan semua objek di dalamnya.
Objek dapat menjadi semua atau sebagian dari antarmuka yang ditampilkan.
Objek dapat berupa komponen yang memformat data khusus untuk dicetak.
Kelas FlexPrintJob memungkinkan Anda menskalakan keluaran agar pas dengan halaman.
Kelas FlexPrintJob secara otomatis menggunakan beberapa halaman untuk mencetak objek yang tidak muat pada satu halaman.
Kelas FlexPrintJob menyebabkan sistem operasi menampilkan kotak dialog Print. Anda tidak dapat mencetak tanpa tindakan pengguna.
Siapkan dan kirim pekerjaan cetak
Anda mencetak keluaran dengan mempersiapkan dan mengirim pekerjaan cetak. Mari buat instance kelas FlexPrintJob
var printJob:FlexPrintJob = new FlexPrintJob();
Mulai pekerjaan cetak
printJob.start();
Flex akan menyebabkan sistem operasi menampilkan kotak dialog Print. Tambahkan satu atau beberapa objek ke pekerjaan cetak dan tentukan cara menskalakannya
printJob.addObject(myObject, FlexPrintJobScaleType.MATCH_WIDTH);
Setiap objek dimulai di halaman baru. Kirim pekerjaan cetak ke printer
printJob.send();
Contoh Pencetakan
Langkah | Deskripsi |
---|---|
1 | Buat proyek dengan nama HelloWorld di bawah paket com.tutorialspoint.client seperti yang dijelaskan di bab Flex - Buat Aplikasi . |
2 | Ubah HelloWorld.mxml seperti yang dijelaskan di bawah ini. Jaga file lainnya tidak berubah. |
3 | Kompilasi dan jalankan aplikasi untuk memastikan logika bisnis berfungsi sesuai kebutuhan. |
Berikut adalah konten file mxml yang dimodifikasi src/com.tutorialspoint/HelloWorld.mxml.
<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
xmlns:s = "library://ns.adobe.com/flex/spark"
xmlns:mx = "library://ns.adobe.com/flex/mx"
width = "100%" height = "100%"
minWidth = "500" minHeight = "500"
initialize = "application_initializeHandler(event)">
<fx:Style source = "/com/tutorialspoint/client/Style.css" />
<fx:Script>
<![CDATA[
import mx.controls.Alert;
import mx.events.FlexEvent;
import mx.printing.FlexPrintJob;
import mx.printing.FlexPrintJobScaleType;
protected function btnClickMe_clickHandler(event:MouseEvent):void {
// Create an instance of the FlexPrintJob class.
var printJob:FlexPrintJob = new FlexPrintJob();
// Start the print job.
if (printJob.start() != true) return;
// Add the object to print. Do not scale it.
printJob.addObject(myDataGrid, FlexPrintJobScaleType.NONE);
// Send the job to the printer.
printJob.send();
}
protected function application_initializeHandler(event:FlexEvent):void {
lblHeader.text = "My Hello World Application";
}
]]>
</fx:Script>
<s:BorderContainer width = "500" height = "500" id = "mainContainer"
styleName = "container">
<s:VGroup width = "100%" height = "100%" gap = "50"
horizontalAlign = "center"
verticalAlign = "middle">
<s:Label id = "lblHeader" fontSize = "40" color = "0x777777"
styleName = "heading" />
<mx:DataGrid id = "myDataGrid" width = "300">
<mx:dataProvider>
<fx:Object Product = "Flex" Code = "1000" />
<fx:Object Product = "GWT" Code = "2000" />
<fx:Object Product = "JAVA" Code = "3000" />
<fx:Object Product = "JUnit" Code = "4000" />
</mx:dataProvider>
</mx:DataGrid>
<s:Button label = "Print Me!" id = "btnClickMe"
click = "btnClickMe_clickHandler(event)"
styleName = "button" />
</s:VGroup>
</s:BorderContainer>
</s:Application>
Setelah Anda siap dengan semua perubahan yang dilakukan, mari kita kompilasi dan jalankan aplikasi dalam mode normal seperti yang kita lakukan di bab Flex - Membuat Aplikasi . Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan menghasilkan hasil sebagai berikut: [ Coba online ]
Klik tombol cetak saya dan Anda dapat melihat hasil cetakan dari data grid yang ditunjukkan di bawah ini.