[med-svn] [Git][med-team/praat][upstream] New upstream version 6.1.34
Rafael Laboissiere
gitlab at salsa.debian.org
Thu Nov 26 12:42:39 GMT 2020
Rafael Laboissiere pushed to branch upstream at Debian Med / praat
Commits:
e799fa2d by Rafael Laboissière at 2020-11-26T06:14:22-03:00
New upstream version 6.1.34
- - - - -
16 changed files:
- README.md
- fon/Matrix.cpp
- fon/SoundRecorder.cpp
- fon/manual_Picture.cpp
- fon/manual_programming.cpp
- fon/manual_sound.cpp
- fon/manual_tutorials.cpp
- + main/praat.svg
- sys/Editor.cpp
- sys/Graphics.h
- sys/GraphicsScreen.cpp
- sys/Graphics_text.cpp
- sys/GuiDrawingArea.cpp
- sys/GuiMenu.cpp
- sys/praat_picture.cpp
- sys/praat_version.h
Changes:
=====================================
README.md
=====================================
@@ -202,7 +202,7 @@ or `praat-build` into a Windows or Linux terminal (or `praat-run` to build and r
### 4.1. MacOS development set-up
Your source code folders, such as `fon` and `sys`, will reside in a folder like `/Users/yourname/Praats/src`,
-where you also put `praat64.xcodeproj`, as described above in 3.2.
+where you also put `praat.xcodeproj`, as described above in 3.2.
On Paul’s 2018 MacBook Pro with Xcode 12.2, building Praat with Command-B or Command-R,
after cleaning the build folder with Shift-Command-K,
takes 120 seconds for the x86_64 part and 110 seconds for the ARM64 part (optimization level O3).
@@ -469,16 +469,16 @@ you include the executable in a `.dmg` disk image, with the following commands:
PRAAT_WWW=~/Praats/www
PRAAT_VERSION=9999
cd ~/builds/mac_products/Configuration64
- hdiutil create -fs HFS+ -ov -srcfolder Praat.app -volname Praat64_${PRAAT_VERSION} praat64_${PRAAT_VERSION}.dmg
- hdiutil convert -ov -format UDZO -o ${PRAAT_WWW}/praat${PRAAT_VERSION}_mac64.dmg praat64_${PRAAT_VERSION}.dmg
- rm praat64_${PRAAT_VERSION}.dmg
+ hdiutil create -fs HFS+ -ov -srcfolder Praat.app -volname Praat_${PRAAT_VERSION} praat_${PRAAT_VERSION}.dmg
+ hdiutil convert -ov -format UDZO -o ${PRAAT_WWW}/praat${PRAAT_VERSION}_mac.dmg praat_${PRAAT_VERSION}.dmg
+ rm praat_${PRAAT_VERSION}.dmg
You also need to distribute the `.xcodeproj` file, which is actually a folder, so that you have to zip it:
# on Mac command line
PRAAT_SOURCES="~/Praats/src
cd $PRAAT_SOURCES
- zip -r $PRAAT_WWW/praat$(PRAAT_VERSION)_xcodeproj64.zip praat64.xcodeproj
+ zip -r $PRAAT_WWW/praat$(PRAAT_VERSION)_xcodeproj.zip praat.xcodeproj
The Windows executables have to be sent from your Cygwin terminal to your Mac.
It is easiest to do this without a version number (so that you have to supply the number only once),
=====================================
fon/Matrix.cpp
=====================================
@@ -437,6 +437,8 @@ void Matrix_paintSurface (Matrix me, Graphics g, double xmin, double xmax, doubl
void Matrix_playMovie (Matrix me, Graphics g) {
Melder_require (my ny >= 2,
me, U": cannot play a movie for a Matrix with less than 2 rows.");
+ if (my xmin == my xmax || my ymin == my ymax)
+ return;
autoVEC column = newVECraw (my ny);
double minimum = 0.0, maximum = 1.0;
Matrix_getWindowExtrema (me, 1, my nx, 1, my ny, & minimum, & maximum);
=====================================
fon/SoundRecorder.cpp
=====================================
@@ -294,6 +294,7 @@ static void showMaximum (SoundRecorder me, int channel, double maximum) {
static void showMeter (SoundRecorder me, const short *buffertje, integer nsamp) {
Melder_assert (my graphics);
+ Graphics_clearWs (my graphics.get());
if (nsamp < 1) {
Graphics_setWindow (my graphics.get(), 0.0, 1.0, 0.0, 1.0);
#if defined (macintosh)
=====================================
fon/manual_Picture.cpp
=====================================
@@ -879,13 +879,8 @@ INTRO (U"One of the commands in the #Select menu of the @@Picture window at .")
ENTRY (U"Purpose")
NORMAL (U"To determine where your next drawing will occur.")
ENTRY (U"The viewport")
-#ifdef macintosh
-NORMAL (U"The \"viewport\" is the part of the Picture window where your next drawing will occur. "
- "You can set the colour of its margins with ##System Preferences \\-> Appearance \\-> Highlight Colour#. ")
-#else
NORMAL (U"The \"viewport\" is the part of the Picture window where your next drawing will occur. "
"Its margins are pink.")
-#endif
NORMAL (U"The %inner viewport does not include the margins, the %outer viewport does (see @@Select outer viewport...@).")
NORMAL (U"Normally, you select the viewport by dragging your mouse across the Picture window. "
"However, you would use this explicit command:")
@@ -898,13 +893,8 @@ INTRO (U"One of the commands in the #Select menu of the @@Picture window at .")
ENTRY (U"Purpose")
NORMAL (U"To determine where your next drawing will occur.")
ENTRY (U"The viewport")
-#ifdef macintosh
-NORMAL (U"The \"viewport\" is the part of the Picture window where your next drawing will occur. "
- "You can set the colour of its margins with ##System Preferences \\-> Appearance \\-> Highlight Colour#. ")
-#else
NORMAL (U"The \"viewport\" is the part of the Picture window where your next drawing will occur. "
"Its margins are pink.")
-#endif
NORMAL (U"The %outer viewport includes the margins, the %inner viewport does not (see @@Select inner viewport...@).")
NORMAL (U"Normally, you select the viewport by dragging your mouse across the Picture window. "
"However, you would use this explicit command:")
=====================================
fon/manual_programming.cpp
=====================================
@@ -1,6 +1,6 @@
/* manual_programming.cpp
*
- * Copyright (C) 1992-2010,2011,2013,2015-2018 Paul Boersma
+ * Copyright (C) 1992-2010,2011,2013,2015-2020 Paul Boersma
*
* This code is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
=====================================
fon/manual_sound.cpp
=====================================
@@ -1,6 +1,6 @@
/* manual_sound.cpp
*
- * Copyright (C) 1992-2008,2010-2012,2014-2017 Paul Boersma
+ * Copyright (C) 1992-2008,2010-2012,2014-2020 Paul Boersma
*
* This code is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -205,9 +205,8 @@ INTRO (U"A command in the @@Open menu@ of the #Objects window. "
"If the file name is hello.wav, Praat will name the channels hello_ch1, hello_ch2, and so on.")
MAN_END
-MAN_BEGIN (U"Record mono Sound...", U"ppgb", 20021212)
-INTRO (U"A command in the @@New menu@ to record a @Sound. Creates a @SoundRecorder window, "
- "except on very old Macintoshes with 8-bit audio, where it presents a native Macintosh sound-recorder window.")
+MAN_BEGIN (U"Record mono Sound...", U"ppgb", 20201120)
+INTRO (U"A command in the @@New menu@ to record a @Sound. Creates a @SoundRecorder window.")
MAN_END
MAN_BEGIN (U"Record stereo Sound...", U"ppgb", 20021212)
@@ -1028,7 +1027,7 @@ NORMAL (U"To synchronize a SoundEditor window with other windows that show a tim
"You cannot Cut from or Paste into a synchronized SoundEditor window.")
MAN_END
-MAN_BEGIN (U"SoundRecorder", U"ppgb", 20110129)
+MAN_BEGIN (U"SoundRecorder", U"ppgb", 20201120)
INTRO (U"With the Praat SoundRecorder window you can record a mono or stereo sound "
"for subsequent viewing and analysis in Praat. "
"The SoundRecorder appears on your screen if you choose @@Record mono Sound...@ or @@Record stereo Sound...@ "
@@ -1050,29 +1049,24 @@ NORMAL (U"The size of the recording buffer determines how many seconds of sound
"or 110 seconds in stereo (220 seconds in mono) at a sampling frequency of 44100 Hz. "
"You can change the size of the recording buffer "
"with ##Sound input prefs...# from the Preferences menu.")
-NORMAL (U"If you recorded a very long sound, it is probable that you cannot copy it to the list of objects. "
- "In such a case, you can still write the sound to disk with one of the #Save commands in the #File menu. "
- "You can then open such a long sound file in Praat with @@Open long sound file...@ from the Open menu.")
-#ifdef macintosh
-ENTRY (U"Recording sounds on MacOS X")
-NORMAL (U"You can record from the combined microphone / line input. On some computers, these are separate.")
-NORMAL (U"Note that in MacOS X you cannot record from the internal CD. This is because the system provides you with something better. "
- "If you open the CD in the Finder, you will see the audio tracks as AIFC files! "
- "To open these audio tracks in Praat, use @@Read from file...@ or @@Open long sound file... at .")
-#endif
-#ifdef _WIN32
-ENTRY (U"Recording sounds in Windows")
-NORMAL (U"In Windows, you can choose your input device with the help of the recording mixer that is supplied by Windows or comes with "
- "your sound card. There will usually be a loudspeaker icon in the Start bar; double-click it, and you will see the %playing mixer "
- "(if there is no loudspeaker icon, go to ##Control Panels#, then ##Sounds and Audio Devices#, then #Volume, then #Advanced; "
- "do not blame us for how Windows XP works). In the playing mixer, choose #Properties from the #Option menu, then click #Recording, "
- "then #OK. You are now in the %recording mixer.")
-NORMAL (U"You can watch the input level only while recording.")
-#endif
+ENTRY (U"Recording sounds on the Mac or in Linux")
+NORMAL (U"On the Mac or in Linux, you can record from the list on the left in the SoundRecorder window. "
+ "The list can contain several devices, such as the internal microphone, a line input, or external USB devices. "
+ "Audio tracks on a CD can be opened directly with @@Read from file...@ or @@Open long sound file... at .")
+ENTRY (U"Recording sounds in Windows 10")
+NORMAL (U"In Windows 10, you can choose your input device by right-clicking on the loudspeaker icon in the Start bar; "
+ "then ##Open Sound settings#, then ##Choose your input device#. "
+ "To set some input #Properties, right-click the loudspeaker icon, then #Sounds, then #Recording.")
+ENTRY (U"Watching the input level")
+NORMAL (U"While recording, you can watch the input level as a green rectangle whose size changes. "
+ "Whenever the input is loud, the top of the rectangle becomes yellow; if it turns red, the sound may have been clipped. "
+ "In the Meter menu you cna choose other visualizations, "
+ "such as a moving ball that measures spectral centre of gravity (horizontally) versus intensity (vertically).")
ENTRY (U"The File menu")
-NORMAL (U"If your computer has little memory, a very long recorded sound can be too big to be copied to the list of objects. "
+NORMAL (U"If your computer has little memory, a very long recorded sound might be too big to be copied to the list of objects. "
"Fortunately, the File menu contains commands to save the recording "
- "to a sound file on disk, so that you will never have to lose your recording.")
+ "to a sound file on disk, so that you will never have to lose your recording. "
+ "You can later open such a long sound file in Praat with @@Open long sound file...@ from the Open menu.")
ENTRY (U"Sound pressure calibration")
NORMAL (U"Your computer's sound-recording software returns integer values between -32768 and 32767. "
"Praat divides them by 32768 before putting them into a Sound object, "
=====================================
fon/manual_tutorials.cpp
=====================================
@@ -22,8 +22,11 @@
void manual_tutorials_init (ManPages me);
void manual_tutorials_init (ManPages me) {
-MAN_BEGIN (U"What's new?", U"ppgb", 20201119)
+MAN_BEGIN (U"What's new?", U"ppgb", 20201125)
INTRO (U"Latest changes in Praat.")
+NORMAL (U"##6.1.34# (25 November 2020)")
+LIST_ITEM (U"• Mac: got bold and italic to work on Praat versions compiled with the BigSur API.")
+LIST_ITEM (U"• SoundRecorder always a white background, instead of a different background on each platform.")
NORMAL (U"##6.1.33# (19 November 2020)")
LIST_ITEM (U"• Mac: got audio to work on Praat versions compiled with the BigSur API (6.1.32 did not have audio on BigSur).")
NORMAL (U"##6.1.32# (16 November 2020)")
@@ -2504,36 +2507,14 @@ LIST_ITEM (U"@@Intro 1.2. Reading a sound from disk")
LIST_ITEM (U"@@Intro 1.3. Creating a sound from a formula")
MAN_END
-MAN_BEGIN (U"Intro 1.1. Recording a sound", U"ppgb", 20110128)
-#ifdef macintosh
- INTRO (U"To record a speech sound into Praat, you need a computer with a microphone.")
- NORMAL (U"To record from the microphone, perform the following steps:")
-#else
- INTRO (U"To record a speech sound into Praat, you need a computer with a microphone. "
- "If you do not have a microphone, try to record from an audio CD instead.")
- NORMAL (U"To record from the microphone (or the CD), perform the following steps:")
-#endif
+MAN_BEGIN (U"Intro 1.1. Recording a sound", U"ppgb", 20201120)
+INTRO (U"To record a speech sound into Praat, you need a computer with a microphone.")
+NORMAL (U"To record from the microphone, perform the following steps:")
LIST_ITEM (U"1. Choose @@Record mono Sound...@ from the @@New menu@ in the @@Object window at . "
"A @SoundRecorder window will appear on your screen.")
-#if defined (_WIN32)
- LIST_ITEM (U"2. Choose the appropriate input device, namely the microphone, by the following steps. "
- "If there is a small loudspeaker symbol in the Windows Start bar, double click it and you will see the %playing mixer. "
- "If there is no loudspeaker symbol, go to ##Control Panels#, then ##Sounds and Audio Devices#, then #Volume, then #Advanced, "
- "and you will finally see the playing mixer. "
- "Once you see the Windows playing mixer, choose #Properties from the #Option menu, "
- "then click #Recording, then #OK. You now see the %recording mixer, where you can select the microphone "
- "(if you do not like this complicated operation, try Praat on Macintosh or Linux instead of Windows).")
-#elif defined (macintosh)
- LIST_ITEM (U"2. In the SoundRecorder window, choose the appropriate input device, e.g. choose ##Internal microphone#.")
-#else
- LIST_ITEM (U"2. In the SoundRecorder window, choose the appropriate input device, i.e. choose #Microphone (or #CD, or #Line).")
-#endif
-#ifdef macintosh
- LIST_ITEM (U"3. Use the #Record and #Stop buttons to record a few seconds of your speech.")
-#else
- LIST_ITEM (U"3. Use the #Record and #Stop buttons to record a few seconds of your speech "
- "(or a few seconds of music from your playing CD).")
-#endif
+LIST_ITEM (U"2. On the left in the SoundRecorder window, choose the appropriate input device, e.g. choose ##Internal microphone#. "
+ "(On Windows, instead right-click the loudspeaker symbol in the Start bar; see @SoundRecorder for more details.)")
+LIST_ITEM (U"3. Use the #Record and #Stop buttons to record a few seconds of your speech.")
LIST_ITEM (U"4. Use the #Play button to hear what you have recorded.")
LIST_ITEM (U"5. Repeat steps 3 and 4 until you are satisfied with your recording.")
LIST_ITEM (U"6. Click the ##Save to list# button. Your recording will now appear in the Object window, "
=====================================
main/praat.svg
=====================================
@@ -0,0 +1 @@
+<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 380 379"><defs><style>.cls-1{isolation:isolate;}.cls-2{opacity:0.35;}.cls-2,.cls-4,.cls-6{mix-blend-mode:multiply;}.cls-3{fill:url(#linear-gradient);}.cls-4{opacity:0.25;}.cls-5{fill:#f7f1f0;}.cls-6{opacity:0.15;}.cls-7{fill:url(#linear-gradient-2);}</style><linearGradient id="linear-gradient" x1="130.08" y1="553.75" x2="472.3" y2="211.53" gradientUnits="userSpaceOnUse"><stop offset="0" stop-color="#b13d5c"/><stop offset="0.18" stop-color="#c34d6a"/><stop offset="0.49" stop-color="#dc637c"/><stop offset="0.77" stop-color="#ec7088"/><stop offset="1" stop-color="#f1758c"/></linearGradient><linearGradient id="linear-gradient-2" x1="259.03" y1="258.2" x2="259.03" y2="258.2" gradientUnits="userSpaceOnUse"><stop offset="0" stop-color="#231f20" stop-opacity="0.87"/><stop offset="0.4" stop-color="#191617" stop-opacity="0.62"/><stop offset="1" stop-opacity="0"/></linearGradient></defs><title>praat</title><g class="cls-1"><g id="Layer_5" data-name="Layer 5"><image class="cls-2" width="380" height="379" xlink:href=""/><path class="cls-3" d="M481.63,233.68V382.37a181.61,181.61,0,0,1-.92,18.31,178.64,178.64,0,0,1-11,46.34c-.38,1-.78,2-1.2,3a176.45,176.45,0,0,1-13.76,27.11c-.93,1.51-1.9,3-2.86,4.49a180.19,180.19,0,0,1-133.39,80.11h0c-3.33.3-6.68.53-10,.66q-3.45.14-6.95.13H151.69a30.93,30.93,0,0,1-30.94-30.95V382.91c0-1.77,0-3.55.08-5.31A180.19,180.19,0,0,1,285,203.43q7.88-.69,15.95-.7H450.69A31,31,0,0,1,481.63,233.68Z" transform="translate(-112 -195)"/><image class="cls-4" width="139" height="171" transform="translate(40.77 189.77)" xlink:href=""/><path class="cls-5" d="M277.89,432.22c-13.88-27.49-45-43.24-75.06-33.74-27,8.55-49.43,35.21-38.18,64.41,6.5,16.84,20.74,28.48,37.19,35l-4.18-10.29a37.58,37.58,0,0,0-.09,37.73c6.77,11.51,19.33,18.42,32.46,19.48,12.25,1,24.83-3.65,32.39-13.55,9.43-12.35,8.61-28.71,2-42.1-4-8.08-16.08-1-12.09,7.06,4.13,8.36,4.91,19.18-1.16,26.87-5,6.28-13.42,8.57-21.12,7.72-17.55-1.92-29.47-20-20.28-36.14,2.43-4.27,0-8.64-4.18-10.28-20-7.93-38.46-30.93-25.74-52.46,11.09-18.76,36.89-26.71,57-19.61,13,4.59,22.9,14.88,29,27,4.06,8.05,16.14,1,12.09-7.06Z" transform="translate(-112 -195)"/><image class="cls-4" width="68" height="95" transform="translate(75.77 223.77)" xlink:href=""/><path class="cls-5" d="M240.07,437.73c-8.72-8-21.88-10.93-32.49-4.7-10,5.91-14,18.19-10.22,29a5.93,5.93,0,0,0,5.48,4.18c14.38.76,27.09,14.5,22.22,29.59-2.26,7,8.71,10,11,3,7.16-22.17-11.32-42.81-33.18-44l5.49,4.17c-2.12-6.08-.9-12.69,5-16.18,6.1-3.61,13.74-1.66,18.71,2.92,5.37,5,13.43-3.07,8-8Z" transform="translate(-112 -195)"/><image class="cls-6" width="162" height="88" transform="translate(126.18 76.18)" xlink:href=""/><path class="cls-5" d="M383,310.59c-27.19,34.28-80.61,37.58-114.78,12.53a69.72,69.72,0,0,1-13.32-12.53v8c27.18-34.28,80.61-37.58,114.77-12.53A69.48,69.48,0,0,1,383,318.63c4.54,5.73,12.53-2.36,8-8-11.07-14-28.42-23.95-45.32-28.8-27.82-8-58.86-2.9-82.44,13.93-6,4.26-11.83,9.1-16.41,14.87a5.94,5.94,0,0,0,0,8c11.08,14,28.43,23.95,45.33,28.8,27.81,8,58.86,2.9,82.43-13.93,6-4.26,11.84-9.1,16.41-14.87S387.55,304.86,383,310.59Z" transform="translate(-112 -195)"/><image class="cls-6" width="293" height="173" transform="translate(61.18 22.18)" xlink:href=""/><path class="cls-5" d="M388,261.91c-6.22-1.87-7.29-6.85-9.56-12.24a42.88,42.88,0,0,0-9.82-14.6,38.06,38.06,0,0,0-32-9.89,34.45,34.45,0,0,0-10.75,3.95c-2.66,1.45-5.16,2.53-8.27,2s-5.89-2.75-8.83-4a32.46,32.46,0,0,0-11.21-2.46A37.92,37.92,0,0,0,268,237.37a48.34,48.34,0,0,0-9.07,16c-2.32,6.54-6.09,7.93-12.45,9.72-12.79,3.58-25.54,8.36-37,15.2-16.39,9.79-32,26-28,46.63,3.31,17.08,19.47,29.08,34,36.53,22.57,11.6,48,17,73.05,19.63a294.1,294.1,0,0,0,86.73-3.67c21.83-4.27,44.76-11.35,62.65-25,13.22-10.12,23.64-25.36,19.08-42.7-5.67-21.59-29.32-33.88-48.42-41.26A190.37,190.37,0,0,0,388,261.91c-9.34-2.44-13.33,12-4,14.47,12,3.12,23.79,7.09,34.66,13.09,7.66,4.23,15.6,9.53,20.45,17,7.57,11.64,3.08,22-6.48,30.81-13.9,12.75-33.58,19.14-51.53,23.49-25.13,6.08-51.26,7.81-77,6.51-23.73-1.2-47.68-5.16-69.92-13.76-13.69-5.3-30-13.59-36.58-27.15a14.46,14.46,0,0,1-1.15-3.13c-.14-.52-.71-3.61-.6-2.67a18.66,18.66,0,0,1,1.35-9.66c3-7.24,9.45-12.87,15.8-17.14,9.67-6.48,20.48-11,31.55-14.49,5.73-1.8,12.12-2.69,17.26-5.95a27,27,0,0,0,10.82-13.84c3.54-9.65,9.4-18,20.3-19.63a19.71,19.71,0,0,1,8.61.54c3.73,1.15,6.82,3.69,10.6,4.8A26.37,26.37,0,0,0,332,242.91c5.51-2.89,10.61-4.06,16.7-2.4a22.89,22.89,0,0,1,12,8c3.87,4.89,4.68,10.86,7.78,16.09A26.72,26.72,0,0,0,384,276.38C393.3,279.16,397.26,264.68,388,261.91Z" transform="translate(-112 -195)"/><path class="cls-7" d="M259,258.2" transform="translate(-112 -195)"/></g></g></svg>
\ No newline at end of file
=====================================
sys/Editor.cpp
=====================================
@@ -321,7 +321,8 @@ static void menu_cb_settingsReport (Editor me, EDITOR_ARGS_DIRECT) {
}
static void menu_cb_info (Editor me, EDITOR_ARGS_DIRECT) {
- if (my data) Thing_info (my data);
+ if (my data)
+ Thing_info (my data);
}
void structEditor :: v_createMenuItems_query (EditorMenu menu) {
@@ -449,7 +450,7 @@ void Editor_init (Editor me, int x, int y, int width, int height, conststring32
top += Machine_getTitleBarHeight ();
bottom += Machine_getTitleBarHeight ();
#endif
- my windowForm = GuiWindow_create (left, top, width, height, 450, 250, title, gui_window_cb_goAway, me, my v_canFullScreen () ? GuiWindow_FULLSCREEN : 0);
+ my windowForm = GuiWindow_create (left, top, width, height, 450, 350, title, gui_window_cb_goAway, me, my v_canFullScreen () ? GuiWindow_FULLSCREEN : 0);
Thing_setName (me, title);
my data = data;
my v_copyPreferencesToInstance ();
=====================================
sys/Graphics.h
=====================================
@@ -334,10 +334,6 @@ void Graphics_marksRightEvery (Graphics me, double units, double distance, bool
void Graphics_marksBottomEvery (Graphics me, double units, double distance, bool haveNumbers, bool haveTicks, bool haveDottedLines);
void Graphics_marksTopEvery (Graphics me, double units, double distance, bool haveNumbers, bool haveTicks, bool haveDottedLines);
-void *Graphics_x_getCR (Graphics me);
-void Graphics_x_setCR (Graphics me, void *cr);
-void *Graphics_x_getGC (Graphics me);
-
bool Graphics_startRecording (Graphics me);
bool Graphics_stopRecording (Graphics me);
void Graphics_clearRecording (Graphics me);
@@ -357,10 +353,5 @@ void Graphics_nextSheetOfPaper (Graphics me);
void Graphics_prefs ();
-#ifdef macintosh
- void GraphicsQuartz_initDraw (Graphics me);
- void GraphicsQuartz_exitDraw (Graphics me);
-#endif
-
/* End of file Graphics.h */
#endif
=====================================
sys/GraphicsScreen.cpp
=====================================
@@ -671,21 +671,4 @@ autoGraphics Graphics_create_pdf (void *context, int resolution,
}
#endif
-#if quartz
- void GraphicsQuartz_initDraw (Graphics me_generic) {
- GraphicsScreen me = static_cast <GraphicsScreen> (me_generic);
- if (my d_macView) {
- my d_macGraphicsContext = Melder_systemVersion < 101400 ?
- (CGContextRef) [[NSGraphicsContext currentContext] graphicsPort] :
- [[NSGraphicsContext currentContext] CGContext];
- Melder_assert (!! my d_macGraphicsContext);
- }
- }
- void GraphicsQuartz_exitDraw (Graphics me_generic) {
- GraphicsScreen me = static_cast <GraphicsScreen> (me_generic);
- if (my d_macView)
- my d_macGraphicsContext = nullptr;
- }
-#endif
-
/* End of file GraphicsScreen.cpp */
=====================================
sys/Graphics_text.cpp
=====================================
@@ -551,6 +551,102 @@ static void charSize (Graphics anyGraphics, _Graphics_widechar *lc) {
}
}
+#if quartz
+static conststring32 quartz_getFontName (int font, int style) {
+ if (Melder_systemVersion < 110000)
+ style = 0; // style extension in the name was not needed on macOS X
+ switch (font) {
+ case (int) kGraphics_font::TIMES:
+ return
+ style == 0 ? U"Times New Roman"
+ : style == Graphics_BOLD ? U"Times New Roman Bold"
+ : style == Graphics_ITALIC ? U"Times New Roman Italic"
+ : U"Times New Roman Bold-Italic";
+ case (int) kGraphics_font::HELVETICA:
+ return
+ style == 0 ? U"Arial"
+ : style == Graphics_BOLD ? U"Arial Bold"
+ : style == Graphics_ITALIC ? U"Arial Italic"
+ : U"Arial Bold-Italic";
+ case (int) kGraphics_font::COURIER:
+ return
+ style == 0 ? U"Courier New"
+ : style == Graphics_BOLD ? U"Courier New Bold"
+ : style == Graphics_ITALIC ? U"Courier New Italic"
+ : U"Courier New Bold-Italic";
+ case (int) kGraphics_font::PALATINO:
+ if (Melder_debug == 900)
+ return U"DG Meta Serif Science";
+ else
+ return style == 0 ? U"Palatino"
+ : style == Graphics_BOLD ? U"Palatino Bold"
+ : style == Graphics_ITALIC ? U"Palatino Italic"
+ : U"Palatino Bold-Italic";
+ case kGraphics_font_SYMBOL:
+ return U"Symbol";
+ case kGraphics_font_IPATIMES:
+ return U"Doulos SIL";
+ case kGraphics_font_IPAPALATINO:
+ return
+ style == 0 ? U"Charis SIL"
+ : style == Graphics_BOLD ? U"Charis SIL Bold"
+ : style == Graphics_ITALIC ? U"Charis SIL Italic"
+ : U"Charis SIL Bold-Italic";
+ case kGraphics_font_DINGBATS:
+ return U"Zapf Dingbats";
+ default:
+ return nullptr;
+ }
+}
+static CTFontRef quartz_getFontRef (int font, int size, int style) {
+ CTFontSymbolicTraits ctStyle = ( style & Graphics_BOLD ? kCTFontBoldTrait : 0 ) | ( style & Graphics_ITALIC ? kCTFontItalicTrait : 0 );
+#if 1
+ CFStringRef key = kCTFontSymbolicTrait;
+ CFNumberRef value = CFNumberCreate (nullptr, kCFNumberIntType, & ctStyle);
+ CFIndex numberOfValues = 1;
+ CFDictionaryRef styleDict = CFDictionaryCreate (nullptr, (const void **) & key, (const void **) & value, numberOfValues,
+ & kCFTypeDictionaryKeyCallBacks, & kCFTypeDictionaryValueCallBacks);
+ CFRelease (value);
+ CFStringRef keys [2];
+ keys [0] = kCTFontTraitsAttribute;
+ keys [1] = kCTFontNameAttribute;
+ conststring32 fontName = quartz_getFontName (font, style);
+ CFStringRef cfFont = (CFStringRef) Melder_peek32toCfstring (fontName);
+ void *values [2] = { (void *) styleDict, (void *) cfFont };
+ CFDictionaryRef attributes = CFDictionaryCreate (nullptr, (const void **) & keys, (const void **) & values, 2,
+ & kCFTypeDictionaryKeyCallBacks, & kCFTypeDictionaryValueCallBacks);
+ CFRelease (styleDict);
+ CTFontDescriptorRef ctFontDescriptor = CTFontDescriptorCreateWithAttributes (attributes);
+ CFRelease (attributes);
+#else
+ NSMutableDictionary *styleDict = [[NSMutableDictionary alloc] initWithCapacity: 1];
+ [styleDict setObject: [NSNumber numberWithUnsignedInt: ctStyle] forKey: (id) kCTFontSymbolicTrait];
+ NSMutableDictionary *attributes = [[NSMutableDictionary alloc] initWithCapacity: 2];
+ [attributes setObject: styleDict forKey: (id) kCTFontTraitsAttribute];
+ switch (font) {
+ case (int) kGraphics_font::TIMES: { [attributes setObject: @"Times New Roman" forKey: (id) kCTFontNameAttribute]; } break;
+ case (int) kGraphics_font::HELVETICA: { [attributes setObject: @"Arial" forKey: (id) kCTFontNameAttribute]; } break;
+ case (int) kGraphics_font::COURIER: { [attributes setObject: @"Courier New" forKey: (id) kCTFontNameAttribute]; } break;
+ case (int) kGraphics_font::PALATINO: { if (Melder_debug == 900)
+ [attributes setObject: @"DG Meta Serif Science" forKey: (id) kCTFontNameAttribute];
+ else
+ [attributes setObject: @"Palatino" forKey: (id) kCTFontNameAttribute];
+ } break;
+ case kGraphics_font_SYMBOL: { [attributes setObject: @"Symbol" forKey: (id) kCTFontNameAttribute]; } break;
+ case kGraphics_font_IPATIMES: { [attributes setObject: @"Doulos SIL" forKey: (id) kCTFontNameAttribute]; } break;
+ case kGraphics_font_IPAPALATINO: { [attributes setObject: @"Charis SIL" forKey: (id) kCTFontNameAttribute]; } break;
+ case kGraphics_font_DINGBATS: { [attributes setObject: @"Zapf Dingbats" forKey: (id) kCTFontNameAttribute]; } break;
+ }
+ CTFontDescriptorRef ctFontDescriptor = CTFontDescriptorCreateWithAttributes ((CFMutableDictionaryRef) attributes);
+ [styleDict release];
+ [attributes release];
+#endif
+ CTFontRef ctFont = CTFontCreateWithFontDescriptor (ctFontDescriptor, size, nullptr);
+ CFRelease (ctFontDescriptor);
+ return ctFont;
+}
+#endif
+
static void charDraw (Graphics anyGraphics, int xDC, int yDC, _Graphics_widechar *lc,
const char32 codes [], int nchars, int width)
{
@@ -696,66 +792,9 @@ static void charDraw (Graphics anyGraphics, int xDC, int yDC, _Graphics_widechar
Determine the font-style combination.
*/
CTFontRef ctFont = theScreenFonts [font] [lc -> size] [style];
- if (! ctFont) {
- CTFontSymbolicTraits ctStyle = ( style & Graphics_BOLD ? kCTFontBoldTrait : 0 ) | ( lc -> style & Graphics_ITALIC ? kCTFontItalicTrait : 0 );
- #if 1
- CFStringRef key = kCTFontSymbolicTrait;
- CFNumberRef value = CFNumberCreate (nullptr, kCFNumberIntType, & ctStyle);
- CFIndex numberOfValues = 1;
- CFDictionaryRef styleDict = CFDictionaryCreate (nullptr, (const void **) & key, (const void **) & value, numberOfValues,
- & kCFTypeDictionaryKeyCallBacks, & kCFTypeDictionaryValueCallBacks);
- CFRelease (value);
- CFStringRef keys [2];
- keys [0] = kCTFontTraitsAttribute;
- keys [1] = kCTFontNameAttribute;
- CFStringRef cfFont;
- switch (font) {
- case (int) kGraphics_font::TIMES: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Times New Roman"); } break;
- case (int) kGraphics_font::HELVETICA: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Arial" ); } break;
- case (int) kGraphics_font::COURIER: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Courier New" ); } break;
- case (int) kGraphics_font::PALATINO: { if (Melder_debug == 900)
- cfFont = (CFStringRef) Melder_peek32toCfstring (U"DG Meta Serif Science");
- else
- cfFont = (CFStringRef) Melder_peek32toCfstring (U"Palatino");
- } break;
- case kGraphics_font_SYMBOL: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Symbol" ); } break;
- case kGraphics_font_IPATIMES: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Doulos SIL" ); } break;
- case kGraphics_font_IPAPALATINO: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Charis SIL" ); } break;
- case kGraphics_font_DINGBATS: { cfFont = (CFStringRef) Melder_peek32toCfstring (U"Zapf Dingbats" ); } break;
- }
- void *values [2] = { (void *) styleDict, (void *) cfFont };
- CFDictionaryRef attributes = CFDictionaryCreate (nullptr, (const void **) & keys, (const void **) & values, 2,
- & kCFTypeDictionaryKeyCallBacks, & kCFTypeDictionaryValueCallBacks);
- CFRelease (styleDict);
- CTFontDescriptorRef ctFontDescriptor = CTFontDescriptorCreateWithAttributes (attributes);
- CFRelease (attributes);
- #else /* Preparing for the time to come when Apple deprecates Core Foundation. */
- NSMutableDictionary *styleDict = [[NSMutableDictionary alloc] initWithCapacity: 1];
- [styleDict setObject: [NSNumber numberWithUnsignedInt: ctStyle] forKey: (id) kCTFontSymbolicTrait];
- NSMutableDictionary *attributes = [[NSMutableDictionary alloc] initWithCapacity: 2];
- [attributes setObject: styleDict forKey: (id) kCTFontTraitsAttribute];
- switch (font) {
- case (int) kGraphics_font::TIMES: { [attributes setObject: @"Times New Roman" forKey: (id) kCTFontNameAttribute]; } break;
- case (int) kGraphics_font::HELVETICA: { [attributes setObject: @"Arial" forKey: (id) kCTFontNameAttribute]; } break;
- case (int) kGraphics_font::COURIER: { [attributes setObject: @"Courier New" forKey: (id) kCTFontNameAttribute]; } break;
- case (int) kGraphics_font::PALATINO: { if (Melder_debug == 900)
- [attributes setObject: @"DG Meta Serif Science" forKey: (id) kCTFontNameAttribute];
- else
- [attributes setObject: @"Palatino" forKey: (id) kCTFontNameAttribute];
- } break;
- case kGraphics_font_SYMBOL: { [attributes setObject: @"Symbol" forKey: (id) kCTFontNameAttribute]; } break;
- case kGraphics_font_IPATIMES: { [attributes setObject: @"Doulos SIL" forKey: (id) kCTFontNameAttribute]; } break;
- case kGraphics_font_IPAPALATINO: { [attributes setObject: @"Charis SIL" forKey: (id) kCTFontNameAttribute]; } break;
- case kGraphics_font_DINGBATS: { [attributes setObject: @"Zapf Dingbats" forKey: (id) kCTFontNameAttribute]; } break;
- }
- CTFontDescriptorRef ctFontDescriptor = CTFontDescriptorCreateWithAttributes ((CFMutableDictionaryRef) attributes);
- [styleDict release];
- [attributes release];
- #endif
- ctFont = CTFontCreateWithFontDescriptor (ctFontDescriptor, lc -> size, nullptr);
- CFRelease (ctFontDescriptor);
- theScreenFonts [font] [lc -> size] [style] = ctFont;
- }
+ if (! ctFont)
+ theScreenFonts [font] [lc -> size] [style] = ctFont =
+ quartz_getFontRef (font, lc -> size, style);
const char16 *codes16 = Melder_peek32to16 (codes);
#if 1
@@ -775,12 +814,9 @@ static void charDraw (Graphics anyGraphics, int xDC, int yDC, _Graphics_widechar
CFRange textRange = CFRangeMake (0, length);
CFAttributedStringSetAttribute (string, textRange, kCTFontAttributeName, ctFont);
- static CFNumberRef cfKerning;
- if (! cfKerning) {
- const double kerning = 0.0;
- cfKerning = CFNumberCreate (kCFAllocatorDefault, kCFNumberDoubleType, & kerning);
- }
- CFAttributedStringSetAttribute (string, textRange, kCTKernAttributeName, cfKerning);
+ /*
+ We don't set kerning explicitly, so that Praat will use standard kerning.
+ */
static CTParagraphStyleRef paragraphStyle;
if (! paragraphStyle) {
@@ -889,40 +925,6 @@ static void charSizes (Graphics me, _Graphics_widechar string [], bool measureEa
int style = lc -> style;
Melder_assert (style >= 0 && style <= Graphics_BOLD_ITALIC);
- #if quartz
- /*
- Determine and store the font-style combination.
- */
- CTFontRef ctFont = theScreenFonts [font] [100] [style];
- if (! ctFont) {
- CTFontSymbolicTraits ctStyle = ( style & Graphics_BOLD ? kCTFontBoldTrait : 0 ) | ( lc -> style & Graphics_ITALIC ? kCTFontItalicTrait : 0 );
- NSMutableDictionary *styleDict = [[NSMutableDictionary alloc] initWithCapacity: 1];
- [styleDict setObject: [NSNumber numberWithUnsignedInt: ctStyle] forKey: (id) kCTFontSymbolicTrait];
- NSMutableDictionary *attributes = [[NSMutableDictionary alloc] initWithCapacity: 2];
- [attributes setObject: styleDict forKey: (id) kCTFontTraitsAttribute];
- switch (font) {
- case (int) kGraphics_font::TIMES: { [attributes setObject: @"Times" forKey: (id) kCTFontNameAttribute]; } break;
- case (int) kGraphics_font::HELVETICA: { [attributes setObject: @"Arial" forKey: (id) kCTFontNameAttribute]; } break;
- case (int) kGraphics_font::COURIER: { [attributes setObject: @"Courier New" forKey: (id) kCTFontNameAttribute]; } break;
- case (int) kGraphics_font::PALATINO: { if (Melder_debug == 900)
- [attributes setObject: @"DG Meta Serif Science" forKey: (id) kCTFontNameAttribute];
- else
- [attributes setObject: @"Palatino" forKey: (id) kCTFontNameAttribute];
- } break;
- case kGraphics_font_SYMBOL: { [attributes setObject: @"Symbol" forKey: (id) kCTFontNameAttribute]; } break;
- case kGraphics_font_IPATIMES: { [attributes setObject: @"Doulos SIL" forKey: (id) kCTFontNameAttribute]; } break;
- case kGraphics_font_IPAPALATINO: { [attributes setObject: @"Charis SIL" forKey: (id) kCTFontNameAttribute]; } break;
- case kGraphics_font_DINGBATS: { [attributes setObject: @"Zapf Dingbats" forKey: (id) kCTFontNameAttribute]; } break;
- }
- CTFontDescriptorRef ctFontDescriptor = CTFontDescriptorCreateWithAttributes ((CFMutableDictionaryRef) attributes);
- [styleDict release];
- [attributes release];
- ctFont = CTFontCreateWithFontDescriptor (ctFontDescriptor, 100.0, nullptr);
- CFRelease (ctFontDescriptor);
- theScreenFonts [font] [100] [style] = ctFont;
- }
- #endif
-
int normalSize = my fontSize * my resolution / 72.0;
int smallSize = (3 * normalSize + 2) / 4;
int size = ( lc -> size < 100 ? smallSize : normalSize );
@@ -930,9 +932,18 @@ static void charSizes (Graphics me, _Graphics_widechar string [], bool measureEa
lc -> baseline *= 0.01 * normalSize;
lc -> code = lc -> kar;
lc -> font.integer_ = font;
- if (Longchar_Info_isDiacritic (info)) {
+ if (Longchar_Info_isDiacritic (info))
numberOfDiacritics ++;
- }
+
+ #if quartz
+ /*
+ Determine and store the font-style combination.
+ */
+ CTFontRef ctFont = theScreenFonts [font] [size] [style];
+ if (! ctFont)
+ theScreenFonts [font] [size] [style] = ctFont =
+ quartz_getFontRef (font, size, style);
+ #endif
}
int nchars = 0;
for (_Graphics_widechar *lc = string; lc -> kar > U'\t'; lc ++) {
@@ -988,7 +999,7 @@ static void charSizes (Graphics me, _Graphics_widechar string [], bool measureEa
CFMutableAttributedStringRef cfstring =
CFAttributedStringCreateMutable (kCFAllocatorDefault, (CFIndex) [s length]);
CFAttributedStringReplaceString (cfstring, CFRangeMake (0, 0), (CFStringRef) s);
- CFAttributedStringSetAttribute (cfstring, textRange, kCTFontAttributeName, theScreenFonts [lc -> font.integer_] [100] [lc -> style]);
+ CFAttributedStringSetAttribute (cfstring, textRange, kCTFontAttributeName, theScreenFonts [lc -> font.integer_] [lc -> size] [lc -> style]);
/*
* Measure.
@@ -1010,7 +1021,7 @@ static void charSizes (Graphics me, _Graphics_widechar string [], bool measureEa
//Longchar_Info info = lc -> karInfo;
//bool isDiacritic = ( info -> ps.times == 0 );
//lc -> width = ( isDiacritic ? 0.0 : frameSize.width * lc -> size / 100.0 );
- lc -> width = frameSize.width * lc -> size / 100.0;
+ lc -> width = frameSize.width /* * lc -> size / 100.0 */;
if (Melder_systemVersion >= 101100) {
/*
* If the text ends in a space, CTFramesetterSuggestFrameSizeWithConstraints() ignores the space.
=====================================
sys/GuiDrawingArea.cpp
=====================================
@@ -36,12 +36,13 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
#endif
#if gtk
- static void _GuiGtkDrawingArea_destroyCallback (GuiObject widget, gpointer void_me) {
+#pragma mark - GTK CALLBACKS (WITH CAIRO)
+ static void _guiGtkDrawingArea_destroyCallback (GuiObject widget, gpointer void_me) {
(void) widget;
iam (GuiDrawingArea);
forget (me);
}
- static gboolean _GuiGtkDrawingArea_drawCallback (GuiObject widget, cairo_t *cairoGraphicsContext, gpointer void_me) {
+ static gboolean _guiGtkDrawingArea_drawCallback (GuiObject widget, cairo_t *cairoGraphicsContext, gpointer void_me) {
trace (U"begin");
iam (GuiDrawingArea);
Melder_assert (me);
@@ -67,7 +68,7 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
return false;
}
static structGuiDrawingArea_MouseEvent::Phase previousPhase = structGuiDrawingArea_MouseEvent::Phase::DROP;
- static gboolean _GuiGtkDrawingArea_mouseDownCallback (GuiObject widget, GdkEvent *e, gpointer void_me) {
+ static gboolean _guiGtkDrawingArea_mouseDownCallback (GuiObject widget, GdkEvent *e, gpointer void_me) {
iam (GuiDrawingArea);
if (my mouseCallback) {
structGuiDrawingArea_MouseEvent event { me, 0 };
@@ -99,7 +100,7 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
}
return false;
}
- static gboolean _GuiGtkDrawingArea_mouseDraggedCallback (GuiObject widget, GdkEvent *e, gpointer void_me) {
+ static gboolean _guiGtkDrawingArea_mouseDraggedCallback (GuiObject widget, GdkEvent *e, gpointer void_me) {
iam (GuiDrawingArea);
if (my mouseCallback) {
structGuiDrawingArea_MouseEvent event { me, 0 };
@@ -118,7 +119,7 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
}
return false;
}
- static gboolean _GuiGtkDrawingArea_mouseUpCallback (GuiObject widget, GdkEvent *e, gpointer void_me) {
+ static gboolean _guiGtkDrawingArea_mouseUpCallback (GuiObject widget, GdkEvent *e, gpointer void_me) {
iam (GuiDrawingArea);
if (my mouseCallback) {
structGuiDrawingArea_MouseEvent event { me, 0 };
@@ -137,7 +138,7 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
}
return false;
}
- static gboolean _GuiGtkDrawingArea_keyCallback (GuiObject widget, GdkEvent *gevent, gpointer void_me) {
+ static gboolean _guiGtkDrawingArea_keyCallback (GuiObject widget, GdkEvent *gevent, gpointer void_me) {
iam (GuiDrawingArea);
trace (U"begin");
if (my d_keyCallback && gevent -> type == GDK_KEY_PRESS) {
@@ -167,7 +168,7 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
}
return false; // if the drawing area has no keyCallback, the system will send the key press to a text field.
}
- static gboolean _GuiGtkDrawingArea_resizeCallback (GuiObject widget, GtkAllocation *allocation, gpointer void_me) {
+ static gboolean _guiGtkDrawingArea_resizeCallback (GuiObject widget, GtkAllocation *allocation, gpointer void_me) {
iam (GuiDrawingArea);
if (my d_resizeCallback) {
structGuiDrawingArea_ResizeEvent event { me, 0 };
@@ -184,7 +185,41 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
}
return false;
}
+ static gboolean _guiGtkDrawingArea_swipeCallback (GuiObject w, GdkEventScroll *event, gpointer void_me) {
+ iam (GuiDrawingArea);
+ trace (U"_guiGtkDrawingArea_swipeCallback ", Melder_pointer (my d_horizontalScrollBar), Melder_pointer (my d_verticalScrollBar));
+ if (my d_horizontalScrollBar) {
+ double hv = gtk_range_get_value (GTK_RANGE (my d_horizontalScrollBar -> d_widget));
+ GtkAdjustment *adjustment = gtk_range_get_adjustment (GTK_RANGE (my d_horizontalScrollBar -> d_widget));
+ gdouble hi;
+ g_object_get (adjustment, "step_increment", & hi, nullptr);
+ switch (event -> direction) {
+ case GDK_SCROLL_LEFT:
+ gtk_range_set_value (GTK_RANGE (my d_horizontalScrollBar -> d_widget), hv - hi);
+ break;
+ case GDK_SCROLL_RIGHT:
+ gtk_range_set_value (GTK_RANGE (my d_horizontalScrollBar -> d_widget), hv + hi);
+ break;
+ }
+ }
+ if (my d_verticalScrollBar) {
+ double vv = gtk_range_get_value (GTK_RANGE (my d_verticalScrollBar -> d_widget));
+ GtkAdjustment *adjustment = gtk_range_get_adjustment (GTK_RANGE (my d_verticalScrollBar -> d_widget));
+ gdouble vi;
+ g_object_get (adjustment, "step_increment", & vi, nullptr);
+ switch (event -> direction) {
+ case GDK_SCROLL_UP:
+ gtk_range_set_value (GTK_RANGE (my d_verticalScrollBar -> d_widget), vv - vi);
+ break;
+ case GDK_SCROLL_DOWN:
+ gtk_range_set_value (GTK_RANGE (my d_verticalScrollBar -> d_widget), vv + vi);
+ break;
+ }
+ }
+ return true;
+ }
#elif motif
+#pragma mark - MOTIF CALLBACKS (WITH GDI)
void _GuiWinDrawingArea_destroy (GuiObject widget) {
iam_drawingarea;
DestroyWindow (widget -> window);
@@ -279,6 +314,7 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
}
}
#elif cocoa
+#pragma mark - COCOA CALLBACKS (WITH QUARTZ)
@interface GuiCocoaDrawingArea ()
@property (nonatomic, assign) BOOL inited;
@property (nonatomic, retain) NSTrackingArea *trackingArea;
@@ -343,11 +379,21 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
Melder_casual (U"\t", Thing_messageNameAndAddress (me), U" draw for ", Melder_pointer (my d_exposeBoss));
try {
Melder_assert (my numberOfGraphicses > 0);
- for (integer igraphics = 1; igraphics <= my numberOfGraphicses; igraphics ++)
- GraphicsQuartz_initDraw (my graphicses [igraphics]);
+ for (integer igraphics = 1; igraphics <= my numberOfGraphicses; igraphics ++) {
+ GraphicsScreen graphics = static_cast <GraphicsScreen> (my graphicses [igraphics]);
+ if (graphics -> d_macView) {
+ graphics -> d_macGraphicsContext = Melder_systemVersion < 101400 ?
+ (CGContextRef) [[NSGraphicsContext currentContext] graphicsPort] :
+ [[NSGraphicsContext currentContext] CGContext];
+ Melder_assert (!! graphics -> d_macGraphicsContext);
+ }
+ }
my d_exposeCallback (my d_exposeBoss, & event);
- for (integer igraphics = 1; igraphics <= my numberOfGraphicses; igraphics ++)
- GraphicsQuartz_exitDraw (my graphicses [igraphics]);
+ for (integer igraphics = 1; igraphics <= my numberOfGraphicses; igraphics ++) {
+ GraphicsScreen graphics = static_cast <GraphicsScreen> (my graphicses [igraphics]);
+ if (graphics -> d_macView)
+ graphics -> d_macGraphicsContext = nullptr;
+ }
} catch (MelderError) {
Melder_flushError (U"Redrawing not completed");
}
@@ -472,49 +518,12 @@ Thing_implement (GuiDrawingArea, GuiControl, 0);
@end
#endif
-#if gtk
- static gboolean _guiGtkDrawingArea_swipeCallback (GuiObject w, GdkEventScroll *event, gpointer void_me) {
- iam (GuiDrawingArea);
- trace (U"_guiGtkDrawingArea_swipeCallback ", Melder_pointer (my d_horizontalScrollBar), Melder_pointer (my d_verticalScrollBar));
- if (my d_horizontalScrollBar) {
- double hv = gtk_range_get_value (GTK_RANGE (my d_horizontalScrollBar -> d_widget));
- GtkAdjustment *adjustment = gtk_range_get_adjustment (GTK_RANGE (my d_horizontalScrollBar -> d_widget));
- gdouble hi;
- g_object_get (adjustment, "step_increment", & hi, nullptr);
- switch (event -> direction) {
- case GDK_SCROLL_LEFT:
- gtk_range_set_value (GTK_RANGE (my d_horizontalScrollBar -> d_widget), hv - hi);
- break;
- case GDK_SCROLL_RIGHT:
- gtk_range_set_value (GTK_RANGE (my d_horizontalScrollBar -> d_widget), hv + hi);
- break;
- }
- }
- if (my d_verticalScrollBar) {
- double vv = gtk_range_get_value (GTK_RANGE (my d_verticalScrollBar -> d_widget));
- GtkAdjustment *adjustment = gtk_range_get_adjustment (GTK_RANGE (my d_verticalScrollBar -> d_widget));
- gdouble vi;
- g_object_get (adjustment, "step_increment", & vi, nullptr);
- switch (event -> direction) {
- case GDK_SCROLL_UP:
- gtk_range_set_value (GTK_RANGE (my d_verticalScrollBar -> d_widget), vv - vi);
- break;
- case GDK_SCROLL_DOWN:
- gtk_range_set_value (GTK_RANGE (my d_verticalScrollBar -> d_widget), vv + vi);
- break;
- }
- }
- return true;
- }
-#endif
-
void structGuiDrawingArea :: v_destroy () noexcept {
if (Melder_debug == 55)
Melder_casual (U"\t", Thing_messageNameAndAddress (this), U" v_destroy");
#if cocoa
- if (our d_widget) {
+ if (our d_widget)
[our d_widget setUserData: nullptr]; // undangle reference to this
- }
#endif
GuiDrawingArea_Parent :: v_destroy ();
}
@@ -548,18 +557,18 @@ GuiDrawingArea GuiDrawingArea_create (GuiForm parent, int left, int right, int t
| GDK_KEY_PRESS_MASK | GDK_KEY_RELEASE_MASK
| GDK_POINTER_MOTION_HINT_MASK); // receive fewer motion notify events (the cb might take time)
gtk_widget_set_events (GTK_WIDGET (my d_widget), mask);
- g_signal_connect (G_OBJECT (my d_widget), "draw", G_CALLBACK (_GuiGtkDrawingArea_drawCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "destroy", G_CALLBACK (_GuiGtkDrawingArea_destroyCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "button-press-event", G_CALLBACK (_GuiGtkDrawingArea_mouseDownCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "button-release-event", G_CALLBACK (_GuiGtkDrawingArea_mouseUpCallback), me.get());
- //g_signal_connect (G_OBJECT (my d_widget), "drag-motion-event", G_CALLBACK (_GuiGtkDrawingArea_mouseUpCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "motion-notify-event", G_CALLBACK (_GuiGtkDrawingArea_mouseDraggedCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "draw", G_CALLBACK (_guiGtkDrawingArea_drawCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "destroy", G_CALLBACK (_guiGtkDrawingArea_destroyCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "button-press-event", G_CALLBACK (_guiGtkDrawingArea_mouseDownCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "button-release-event", G_CALLBACK (_guiGtkDrawingArea_mouseUpCallback), me.get());
+ //g_signal_connect (G_OBJECT (my d_widget), "drag-motion-event", G_CALLBACK (_guiGtkDrawingArea_mouseUpCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "motion-notify-event", G_CALLBACK (_guiGtkDrawingArea_mouseDraggedCallback), me.get());
if (parent) {
Melder_assert (parent -> d_widget);
g_signal_connect (G_OBJECT (gtk_widget_get_toplevel (GTK_WIDGET (parent -> d_widget))), "key-press-event",
- G_CALLBACK (_GuiGtkDrawingArea_keyCallback), me.get());
+ G_CALLBACK (_guiGtkDrawingArea_keyCallback), me.get());
}
- g_signal_connect (G_OBJECT (my d_widget), "size-allocate", G_CALLBACK (_GuiGtkDrawingArea_resizeCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "size-allocate", G_CALLBACK (_guiGtkDrawingArea_resizeCallback), me.get());
_GuiObject_setUserData (my d_widget, me.get());
my v_positionInForm (my d_widget, left, right, top, bottom, parent);
@@ -627,16 +636,16 @@ GuiDrawingArea GuiDrawingArea_create (GuiScrolledWindow parent, int width, int h
| GDK_KEY_PRESS_MASK | GDK_KEY_RELEASE_MASK
| GDK_POINTER_MOTION_HINT_MASK); // receive fewer motion notify events (the cb might take time)
gtk_widget_set_events (GTK_WIDGET (my d_widget), mask);
- g_signal_connect (G_OBJECT (my d_widget), "draw", G_CALLBACK (_GuiGtkDrawingArea_drawCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "destroy", G_CALLBACK (_GuiGtkDrawingArea_destroyCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "button-press-event", G_CALLBACK (_GuiGtkDrawingArea_mouseDownCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "button-release-event", G_CALLBACK (_GuiGtkDrawingArea_mouseUpCallback), me.get());
- g_signal_connect (G_OBJECT (my d_widget), "motion-notify-event", G_CALLBACK (_GuiGtkDrawingArea_mouseDraggedCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "draw", G_CALLBACK (_guiGtkDrawingArea_drawCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "destroy", G_CALLBACK (_guiGtkDrawingArea_destroyCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "button-press-event", G_CALLBACK (_guiGtkDrawingArea_mouseDownCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "button-release-event", G_CALLBACK (_guiGtkDrawingArea_mouseUpCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "motion-notify-event", G_CALLBACK (_guiGtkDrawingArea_mouseDraggedCallback), me.get());
if (parent) {
g_signal_connect (G_OBJECT (gtk_widget_get_toplevel (GTK_WIDGET (parent -> d_widget))), "key-press-event",
- G_CALLBACK (_GuiGtkDrawingArea_keyCallback), me.get());
+ G_CALLBACK (_guiGtkDrawingArea_keyCallback), me.get());
}
- g_signal_connect (G_OBJECT (my d_widget), "size-allocate", G_CALLBACK (_GuiGtkDrawingArea_resizeCallback), me.get());
+ g_signal_connect (G_OBJECT (my d_widget), "size-allocate", G_CALLBACK (_guiGtkDrawingArea_resizeCallback), me.get());
_GuiObject_setUserData (my d_widget, me.get());
my v_positionInScrolledWindow (my d_widget, width, height, parent);
#elif motif
=====================================
sys/GuiMenu.cpp
=====================================
@@ -48,6 +48,15 @@ void structGuiMenu :: v_destroy () noexcept {
trace (U"destroying GuiButton ", Melder_pointer (my d_cascadeButton.get()));
gtk_widget_destroy (GTK_WIDGET (my d_widget));
}
+ static gint _guiGtkMenuCascadeButton_buttonCallback (GtkWidget *gtkMenu, GdkEvent *gdkEvent) {
+ if (gdkEvent -> type == GDK_BUTTON_PRESS) {
+ GtkWidget *gtkCascadeButton = (GtkWidget *) g_object_get_data (G_OBJECT (gtkMenu), "button");
+ gtk_menu_popup_at_widget (GTK_MENU (gtkMenu), GTK_WIDGET (gtkCascadeButton),
+ GDK_GRAVITY_SOUTH_WEST, GDK_GRAVITY_NORTH_WEST, gdkEvent);
+ return true;
+ }
+ return false;
+ }
#elif motif
static void _guiMotifMenu_destroyCallback (GuiObject widget, XtPointer void_me, XtPointer call) {
(void) void_me;
@@ -344,7 +353,7 @@ GuiMenu GuiMenu_createInWindow (GuiWindow window, conststring32 title, uint32 fl
_GuiObject_setUserData (my d_widget, me.get());
#elif cocoa
if (! theMenuBar) {
- int numberOfMenus = [[[NSApp mainMenu] itemArray] count];
+ integer numberOfMenus = uinteger_to_integer ([[[NSApp mainMenu] itemArray] count]);
trace (U"Number of menus: ", numberOfMenus);
[NSApp setDelegate: NSApp]; // the app is its own delegate
theMenuBar = [[NSMenu alloc] init];
@@ -363,10 +372,10 @@ GuiMenu GuiMenu_createInWindow (GuiWindow window, conststring32 title, uint32 fl
*/
NSString *itemTitle = (NSString *) Melder_peek32toCfstring (title);
my d_cocoaMenuItem = [[GuiCocoaMenuItem alloc]
- initWithTitle: itemTitle action: nullptr keyEquivalent: @""];
+ initWithTitle: itemTitle action: nullptr keyEquivalent: @""];
[my d_cocoaMenuItem setSubmenu: my d_cocoaMenu]; // the item will retain the menu...
- [my d_cocoaMenu release]; // ... so we can release the menu already (before even returning it!)
+ [my d_cocoaMenu release]; // ... so we can release the menu already (before even returning it!)
theMenuBarItems [++ theNumberOfMenuBarItems] = my d_cocoaMenuItem;
} else if ([(NSView *) window -> d_widget isKindOfClass: [NSView class]]) {
/*
@@ -395,7 +404,7 @@ GuiMenu GuiMenu_createInWindow (GuiWindow window, conststring32 title, uint32 fl
//[nsPopupButton setBordered: NO];
[my d_cocoaMenuButton setAutoresizingMask: resizingMask]; // stick to top
if (flags & GuiMenu_INSENSITIVE)
- [my d_cocoaMenuButton setEnabled: NO];
+ [my d_cocoaMenuButton setEnabled: NO];
[[my d_cocoaMenuButton cell] setArrowPosition: NSPopUpNoArrow /*NSPopUpArrowAtBottom*/];
[[my d_cocoaMenuButton cell] setPreferredEdge: NSMaxYEdge];
@@ -465,7 +474,7 @@ GuiMenu GuiMenu_createInMenu (GuiMenu supermenu, conststring32 title, uint32 fla
action: nullptr
keyEquivalent: @""];
trace (U"adding the item to its supermenu ", Melder_pointer (supermenu));
- [supermenu -> d_cocoaMenu addItem: item]; // the menu will retain the item...
+ [supermenu -> d_cocoaMenu addItem: item]; // the menu will retain the item...
trace (U"release the item");
[item release]; // ... so we can release the item already
trace (U"creating menu ", title);
@@ -476,7 +485,7 @@ GuiMenu GuiMenu_createInMenu (GuiMenu supermenu, conststring32 title, uint32 fla
trace (U"adding the new menu ", Melder_pointer (me.get()), U" to its supermenu ", Melder_pointer (supermenu));
[supermenu -> d_cocoaMenu setSubmenu: my d_cocoaMenu forItem: item]; // the supermenu will retain the menu...
Melder_assert ([my d_cocoaMenu retainCount] == 2);
- [my d_cocoaMenu release]; // ... so we can release the menu already, even before returning it
+ [my d_cocoaMenu release]; // ... so we can release the menu already, even before returning it
my d_widget = my d_cocoaMenu;
my d_menuItem -> d_widget = (GuiObject) item;
#endif
@@ -490,40 +499,6 @@ GuiMenu GuiMenu_createInMenu (GuiMenu supermenu, conststring32 title, uint32 fla
return me.releaseToAmbiguousOwner();
}
-#if gtk
- static void set_position (GtkMenu *menu, gint *px, gint *py, gpointer data)
- {
- //gint w, h;
- GtkWidget *button = (GtkWidget *) g_object_get_data (G_OBJECT (menu), "button");
- GtkAllocation button_allocation;
- gtk_widget_get_allocation (GTK_WIDGET (button), & button_allocation);
- GtkRequisition menu_requisition;
- gtk_widget_get_child_requisition (GTK_WIDGET (menu), & menu_requisition);
- //if (GTK_WIDGET (menu) -> requisition. width < button_allocation.width)
- if (menu_requisition. width < button_allocation.width)
- gtk_widget_set_size_request (GTK_WIDGET (menu), button_allocation.width, -1);
-
- gdk_window_get_origin (gtk_widget_get_window (button), px, py);
- *px += button_allocation.x;
- *py += button_allocation.y + button_allocation.height; /* Dit is vreemd */
-
- }
- static gint button_press (GtkWidget *widget, GdkEvent *event)
- {
- /* GtkWidget *button = (GtkWidget *) g_object_get_data (G_OBJECT (widget), "button");
- gint w, h;
- gdk_window_get_size (button->window, &w, &h);
- gtk_widget_set_usize (widget, w, 0);*/
-
- if (event->type == GDK_BUTTON_PRESS) {
- GdkEventButton *bevent = (GdkEventButton *) event;
- gtk_menu_popup (GTK_MENU (widget), nullptr, nullptr, (GtkMenuPositionFunc) set_position, nullptr, bevent->button, bevent->time);
- return true;
- }
- return false;
- }
-#endif
-
GuiMenu GuiMenu_createInForm (GuiForm form, int left, int right, int top, int bottom, conststring32 title, uint32 flags) {
autoGuiMenu me = Thing_new (GuiMenu);
my d_shell = form -> d_shell;
@@ -541,9 +516,9 @@ GuiMenu GuiMenu_createInForm (GuiForm form, int left, int right, int top, int bo
if (flags & GuiMenu_INSENSITIVE)
gtk_widget_set_sensitive (GTK_WIDGET (my d_widget), false);
- g_signal_connect_object (G_OBJECT (my d_cascadeButton -> d_widget), "event",
- G_CALLBACK (button_press), G_OBJECT (my d_widget), G_CONNECT_SWAPPED);
g_object_set_data (G_OBJECT (my d_widget), "button", my d_cascadeButton -> d_widget);
+ g_signal_connect_object (G_OBJECT (my d_cascadeButton -> d_widget), "event",
+ G_CALLBACK (_guiGtkMenuCascadeButton_buttonCallback), G_OBJECT (my d_widget), G_CONNECT_SWAPPED);
gtk_menu_attach_to_widget (GTK_MENU (my d_widget), GTK_WIDGET (my d_cascadeButton -> d_widget), nullptr);
gtk_button_set_alignment (GTK_BUTTON (my d_cascadeButton -> d_widget), 0.5f, 0.5f);
_GuiObject_setUserData (my d_widget, me.get());
@@ -571,7 +546,7 @@ GuiMenu GuiMenu_createInForm (GuiForm form, int left, int right, int top, int bo
[[my d_cocoaMenuButton cell] setArrowPosition: NSPopUpNoArrow /*NSPopUpArrowAtBottom*/];
NSString *menuTitle = (NSString*) Melder_peek32toCfstring (title);
- my d_widget = my d_cocoaMenu = [[GuiCocoaMenu alloc] initWithTitle:menuTitle];
+ my d_widget = my d_cocoaMenu = [[GuiCocoaMenu alloc] initWithTitle: menuTitle];
[my d_cocoaMenu setAutoenablesItems: NO];
/*
Apparently, Cocoa swallows title setting only if there is already a menu with a dummy item.
=====================================
sys/praat_picture.cpp
=====================================
@@ -45,8 +45,10 @@ static GuiMenuItem praatButton_fonts [1 + (int) kGraphics_font::MAX];
static void updateFontMenu () {
if (! theCurrentPraatApplication -> batch) {
- if (theCurrentPraatPicture -> font < (int) kGraphics_font::MIN) theCurrentPraatPicture -> font = (int) kGraphics_font::MIN;
- if (theCurrentPraatPicture -> font > (int) kGraphics_font::MAX) theCurrentPraatPicture -> font = (int) kGraphics_font::MAX;
+ if (theCurrentPraatPicture -> font < (int) kGraphics_font::MIN)
+ theCurrentPraatPicture -> font = (int) kGraphics_font::MIN;
+ if (theCurrentPraatPicture -> font > (int) kGraphics_font::MAX)
+ theCurrentPraatPicture -> font = (int) kGraphics_font::MAX;
for (int i = (int) kGraphics_font::MIN; i <= (int) kGraphics_font::MAX; i ++) {
GuiMenuItem_check (praatButton_fonts [i], theCurrentPraatPicture -> font == i);
}
=====================================
sys/praat_version.h
=====================================
@@ -1,5 +1,5 @@
-#define PRAAT_VERSION_STR 6.1.33
-#define PRAAT_VERSION_NUM 6133
+#define PRAAT_VERSION_STR 6.1.34
+#define PRAAT_VERSION_NUM 6134
#define PRAAT_YEAR 2020
#define PRAAT_MONTH November
-#define PRAAT_DAY 19
+#define PRAAT_DAY 25
View it on GitLab: https://salsa.debian.org/med-team/praat/-/commit/e799fa2d0b9c54551bcf2cb5ef0e1c8397d56ed7
--
View it on GitLab: https://salsa.debian.org/med-team/praat/-/commit/e799fa2d0b9c54551bcf2cb5ef0e1c8397d56ed7
You're receiving this email because of your account on salsa.debian.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/debian-med-commit/attachments/20201126/741d0545/attachment-0001.html>
More information about the debian-med-commit
mailing list