מודולים

Ink API הוא מודולרי, כך שאפשר להשתמש רק במה שצריך.

תנועות

מודול התנועות משמש כבסיס ל-Ink API. סוגי הנתונים העיקריים במודול הזה הם:

  • StrokeInputBatch: מייצג סדרה של קלט מצביע, כולל המיקום, חותמת הזמן, ולחץ, הטיה וכיוון (אופציונלי).
  • InProgressStroke: מייצג קו שנמצא בתהליך ציור. ‫InProgressStroke משמש לעיבוד של קווים חלקיים עם זמן אחזור נמוך, וליצירת Stroke סופי אחרי שהקלט מסתיים, ואז אפשר לעשות שימוש חוזר באובייקט. ‫`InProgressStroke נמצא בשימוש על ידי InProgressStrokesView.
  • Stroke: ייצוג קבוע של קו סופי עם גיאומטריה קבועה. לכל Stroke יש ImmutableStrokeInputBatch (נקודות קלט), Brush (סגנון) וPartitionedMesh (צורה גיאומטרית). אתם יכולים לאחסן, לשנות ולעבד את הקווים באפליקציה.

גיאומטריה

מודול Geometry תומך בפעולות גיאומטריות על צורות פרימיטיביות (באמצעות מחלקות ייעודיות כמו Box ו-Vec), וגם על צורות שרירותיות (באמצעות PartitionedMesh), כולל זיהוי של חיתוך ושינוי. ‫PartitionedMesh יכול להכיל גם נתונים נוספים לתמיכה בעיבוד.

מכחול

מודול brush מגדיר את סגנון הקווים. הוא מורכב משני חלקים עיקריים:

  • Brush: מציין את הסגנון של קו, כולל צבע בסיסי, גודל בסיסי ו-BrushFamily. ‫BrushFamily דומה למשפחת גופנים, הוא מגדיר את הסגנון של קו. לדוגמה, BrushFamily יכול לייצג סגנון ספציפי של טוש או מרקר, כך שקווי מתאר במידות ובצבעים שונים ישתמשו באותו סגנון.
  • StockBrushes: מספק פונקציות ליצירת מופעים של BrushFamily שמוכנים לשימוש.

יצירת תוכן

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

אחרי שמסיימים לצייר קו, התצוגה מודיעה לאפליקציית הלקוח באמצעות קריאה חוזרת רשומה (InProgressStrokesFinishedListener). הקריאה החוזרת מאפשרת לאפליקציה לאחזר את הקו שסיימו לצייר כדי להציג אותו או לאחסן אותו.

רינדור

מודול העיבוד עוזר לכם לצייר קווים של דיו על מכשיר Android‏ Canvas. הוא מספק CanvasStrokeRenderer לכתיבה וViewStrokeRenderer לפריסות מבוססות-תצוגה. המעבדים האלה נועדו לעיבוד מהיר של הגרפיקה, והם עוזרים לספק תוכן ויזואלי באיכות גבוהה, כולל החלקת קצוות.

כדי לעבד קווים, צריך להפעיל את method‏ create() כדי לקבל מופע של CanvasStrokeRenderer. לאחר מכן, קוראים לשיטה draw() כדי לעבד קווים שהושלמו (Stroke) או קווים בתהליך (InProgressStroke) על Canvas.

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

כדי להימנע ממעקב נפרד של טרנספורמציית canvas, משתמשים במקום זאת ב-ViewStrokeRenderer.

אחסון

מודול האחסון מספק כלי עזר לסדרות ולביטול סדרות של נתוני משיכות מכחול בצורה יעילה, ומתמקד בעיקר ב-StrokeInputBatch.

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

מודול האחסון מפשט את השמירה, הטעינה והשיתוף של משיכות המכחול.