אינטרנט ישראל
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
ראשי » מדריכים » Open Flash Chart » שינויים למתקדמים ב-Open Flash Chart

שינויים למתקדמים ב-Open Flash Chart

רן בר-זיק פברואר 25, 2010 7:06 am אין תגובות

הסברים על פונקציות מתקדמות ב-Open Flash Chart

אזהרה: Open Flash Chart נחשב כיום כמיושן ועדיף מאוד לא להשתמש בו. במידה ואתם רוצים להטמיע גרפים באתר שלכם, הפתרון הפופולרי הוא Google Charts.
כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.
אזהרה: Open Flash Chart נחשב כיום כמיושן ועדיף מאוד לא להשתמש בו. במידה ואתם רוצים להטמיע גרפים באתר שלכם, הפתרון הפופולרי הוא Google Charts.

במאמרים הקודמים למדנו על סוגי גרפים שונים ב-Open Flash Chart: גרף קווי, גרף עוגה וגרף עמודות. בנוסף למדנו על כיצד להכניס את אובייקט הפלאש לתוך הדף וליצור קשר עם ספרית ה-PHP שמייצרת את אובייקט ה-JSON.

כאשר אנו מכניסים את אובייקט הפלאש לדף באמצעות swfobject, אנו מסוגלים לקבוע עוד כמה פרמטרים שיאפשרו לנו לשנות את התנהגות הפלאש עצמו. במאמר זה אנו נלמד על הפרמטרים האלו.

שינוי של הודעת טעינה

על ידי הוספת הפרמטר 'loading' לפלאש עם הטקסט שאנו רוצים שיהיה כתוב בו, אנו יכולים לשנות את הטקסט של הודעת הטעינה. למשל:
(אנא רפרשו את הדף על מנת לראות את הודעת הטעינה).

והנה הקוד שבו השתמשתי:


swfobject.embedSWF(
  "https://internet-israel.com/internet_files/openflashchart/open-flash-chart.swf", "my-flash-chart-1", "500", "400",
  "9.0.0",null,
  {"data-file":"https%3A%2F%2Finternet-israel.com%2Finternet_files%2Fopenflashchart%2Fofc-json-E1.php", "loading":"Customise the loading message..."}
  );


הוספת פונקצית JavaScript שתופעל על ידי לחיצה בגרף

נניח שאני רוצה שפונקצית JavaScript תופעל אם המשתמש לוחץ על נקודה מסוימת בדף. אין דבר קל מזה. כל מה שעלי לעשות זה ליצור את פונקציה ה-JavaScript ואז לקשר אליה באמצעות מתודה שנקראת on_click.

ראשית ניצור את פונקצית ה-JavaScript ואת פונקצית swftools שמכניסה את הפלאש לדף שלנו בצד הקליינט.


swfobject.embedSWF(
"https://internet-israel.com/internet_files/openflashchart/open-flash-chart.swf", "my-flash-chart-2", "500", "400",
"9.0.0",null,
{"data-file":"https%3A%2F%2Finternet-israel.com%2Finternet_files%2Fopenflashchart%2Fofc-json-E2.php"}
);

  
 function alertMePlease(index) {
	alert('Hello from '+ index);
 }

שימו לב לפונקצית alertMePlease – היא מקבלת ארגומנט אחד שהוא האינדקס של הנקודה. אם הנקודה במיקום הראשון האינדקס יהיה אפס.

עכשיו, עלי להשתמש במתודת on_click על מנת להעביר את שם הפונקציה. במקרה שלנו alertMePlease. בגרפים מסוג עמודה או עוגה, מתודת on_click נמצאת באובייקט bar או pie. בגרף קווי המתודה הזו נמצאת בנקודה של הגרף.


< ?php
require_once('php-ofc-library/open-flash-chart.php');


//יצירת אובייקט גרף קווי

$d = new solid_dot();
$d->on_click('alertMePlease');

//יצירת קו חדש
$line_1 = new line();
$line_1->set_values( array(5, 2, 1, 4, 3,5, 2, 1, 4, 3,5, 2, 1, 4, 3,5, 2, 1, 4, 3,5, 2, 1, 4, 3,5, 2, 1, 4, 3,5, 2, 1, 4, 3,5, 2, 1, 4, 3) );
$line_1->set_text('My Profits');
$line_1->set_default_dot_style($d);

//יצירת אובייקט גרף והצמדה של אובייקט הגרף הקווי
$chart = new open_flash_chart();

$chart->add_element($line_1);

//הדפסה של ה-JSON
print $chart->toPrettyString();

והנה ההדגמה החיה – נסו ללחוץ על הנקודות!

שמירה כתמונה

אם נלחץ על הכפתור הימני כאשר העכבר נמצא על הגרף, אנו נראה שיש לנו 'Save Image Locally' על מנת לגרום לכפתור הזה לעבוד, עלינו להכניס קוד JavaScript קטן עם jQuery.

ראשית עלינו להכליל את ספרית jQuery בקוד שלנו. אם אתם לא מכירים jQuery מספיק טוב, לא צריך להבהל. כל מה שצריך לעשות זה להכניס קישור לספרית jQuery כמו בדוגמה הבאה:


<script type="text/javascript" src="https://internet-israel.com/scripts/jquery.js"></script>

אחרי כן אנחנו משתמשים בקוד ה-JavaScript הבא (חייב להיות לאחר קוד ה-jQuery) :


OFC = {};
 
OFC.jquery = {
    name: "jQuery",
    version: function(src) { return $('#'+ src)[0].get_version() },
    rasterize: function (src, dst) { $('#'+ dst).replaceWith(OFC.jquery.image(src)) },
    image: function(src) { return "<img src='data:image/png;base64," + $('#'+src)[0].get_img_binary() + "' />"},
    popup: function(src) {
        var img_win = window.open('', 'Charts: Export as Image')
        with(img_win.document) {
            write('Charts: Export as Image< \/title>< \/head><body>' + OFC.jquery.image(src) + '< \/body>< \/html>') }
		// stop the 'loading...' message
		img_win.document.close();
     }
}
 
// Using an object as namespaces is JS Best Practice. I like the Control.XXX style.
//if (!Control) {var Control = {}}
//if (typeof(Control == "undefined")) {var Control = {}}
if (typeof(Control == "undefined")) {var Control = {OFC: OFC.jquery}}
 
 
// By default, right-clicking on OFC and choosing "save image locally" calls this function.
// You are free to change the code in OFC and call my wrapper (Control.OFC.your_favorite_save_method)
// function save_image() { alert(1); Control.OFC.popup('my_chart') }
function save_image() { alert(1); OFC.jquery.popup('<strong>my-flash-chart-3</strong>') }</body>

כאשר אנו מקפידים להחליף את my-flash-chart-3 ב-id של ה-div שמכיל את הגרף. זה שאנו קוראים לו בפונקצית swftools שבאמצעותה אנו מכניסים את הגרף.

והנה הדוגמא:

הערת נגישות: כידוע, פלאש היא טכנולוגיה לא נגישה וחלק מהמשתמשים (כמו למשל כאלו שמשתמשים באייפון או כאלו שסובלים מלקות ראיה) לא מסוגלים להשתמש בפלאש כי המערכת שלהם לא תומכת בכך. חובה לספק להם דרך אלטרנטיבית לראות את הנתונים. הדרך המקובלת היא באמצעות טבלת נתונים המכילה את הנתונים שיש בגרף.

אזהרה: Open Flash Chart נחשב כיום כמיושן ועדיף מאוד לא להשתמש בו. במידה ואתם רוצים להטמיע גרפים באתר שלכם, הפתרון הפופולרי הוא Google Charts.
כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.
Open Flash Chart גרפים פלאש
ללמוד ג'אווהסקריפט בעברית

ללמוד לתכנת ג'אווהסקריפט בעברית שגייס יותר משלוש מאות אלף שקל ולמעלה מ-2000 תומכים - בואו ללמוד עכשיו איך לתכנת.

רשימת הנושאים
  • מדריכים
    • ריאקט
    • טייפסקריפט
    • ECMAScript 6
    • ES20XX
    • Node.js
    • Express
    • רספברי פיי
    • Babel
    • docker
    • MongoDB
    • Git
    • לימוד MySQL
    • SASS
    • jQuery
    • CSS3
    • HTML 5
    • SVN
    • LESS
  • פיתוח אינטרנט
    • פתרונות ומאמרים על פיתוח אינטרנט
    • jQuery Scripts
    • jQuery למתקדמים
    • יסודות בתכנות
    • נגישות אינטרנט
  • חדשות אינטרנט
  • מידע כללי על אינטרנט
    • רשת האינטרנט
    • בניית אתרי אינטרנט
  • rss logo

    לכל המאמרים

    לכל המאמרים שפורסמו באינטרנט ישראל משנת 2008 ועד עכשיו.
  • rss logo

    RSS Feed

    משתמשים בקורא RSS? אם כן, עקבו אחרי אינטרנט ישראל באמצעות פיד ה-RSS!
    מה זה RSS?
  • Twitter logo

    עקבו אחרי בטוויטר

    בחשבון הטוויטר שלי אני מפרסם עדכונים מהירים על חדשות בתחום התכנות והיזמות, התרעות על מצבי חירום ורכילות בוערת על תחום הווב.
    מה זה טוויטר?
  • facebook like image

    ערוץ הטלגרם של אינטרנט ישראל

    בערוץ הטלגרם של אינטרנט ישראל אני מפרסם את הפוסטים של באתר וכן עדכונים טכנולוגיים נוספים.
    מה זה טלגרם?
  • github logo

    הפרויקטים שלי בגיטהאב

    הפרויקטים שאני כותב ושוחררו לציבור ברישיון קוד פתוח נמצאים ברובם בגיטהאב.
חיפוש

כל הזכויות שמורות לרן בר-זיק ולאינטרנט ישראל | מדיניות הפרטיות של אתר אינטרנט ישראל | אתר אינטרנט ישראל נגיש לפי תקן WCAG 2.0 AA | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

גלילה לראש העמוד